首页 > 数据库 >Docker启动Nacos2.4.3并且使用MySQL

Docker启动Nacos2.4.3并且使用MySQL

时间:2024-12-12 22:53:34浏览次数:6  
标签:SERVICE MYSQL Nacos2.4 nacos auth server MySQL docker Docker

1.拉取容器

docker pull nacos/nacos-server:v2.4.3

2.创建宿主机挂载目录

mkdir -p /docker/nacos/logs/
mkdir -p /docker/nacos/conf/

3.启动临时容器并拷贝配置文件

  • 启动临时容器
  • docker run -d --name nacos-temp -p 8848:8848 nacos/nacos-server:v2.4.3
  • 拷贝Nacos配置
  • docker cp nacos-temp:/home/nacos/logs/ /data/nacos/
    docker cp nacos-temp:/home/nacos/conf/ /data/nacos/
  • 移除临时容器
  • docker rm -f nacos-temp

4.查看宿主机的conf的application.properties配置文件是如下:

# spring
server.servlet.contextPath=${SERVER_SERVLET_CONTEXTPATH:/nacos}
server.contextPath=/nacos
server.port=${NACOS_APPLICATION_PORT:8848}
server.tomcat.accesslog.max-days=30
server.tomcat.accesslog.pattern=%h %l %u %t "%r" %s %b %D %{User-Agent}i %{Request-Source}i
server.tomcat.accesslog.enabled=${TOMCAT_ACCESSLOG_ENABLED:false}
server.error.include-message=ALWAYS
# default current work dir
server.tomcat.basedir=file:.
#*************** Config Module Related Configurations ***************#
### Deprecated configuration property, it is recommended to use `spring.sql.init.platform` replaced.
#spring.datasource.platform=${SPRING_DATASOURCE_PLATFORM:}
spring.sql.init.platform=${SPRING_DATASOURCE_PLATFORM:}
nacos.cmdb.dumpTaskInterval=3600
nacos.cmdb.eventTaskInterval=10
nacos.cmdb.labelTaskInterval=300
nacos.cmdb.loadDataAtStart=false
db.num=${MYSQL_DATABASE_NUM:1}
db.url.0=jdbc:mysql://${MYSQL_SERVICE_HOST}:${MYSQL_SERVICE_PORT:3306}/${MYSQL_SERVICE_DB_NAME}?${MYSQL_SERVICE_DB_PARAM:characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useSSL=false}
db.user.0=${MYSQL_SERVICE_USER}
db.password.0=${MYSQL_SERVICE_PASSWORD}
## DB connection pool settings
db.pool.config.connectionTimeout=${DB_POOL_CONNECTION_TIMEOUT:30000}
db.pool.config.validationTimeout=10000
db.pool.config.maximumPoolSize=20
db.pool.config.minimumIdle=2
### The auth system to use, currently only 'nacos' and 'ldap' is supported:
nacos.core.auth.system.type=${NACOS_AUTH_SYSTEM_TYPE:nacos}
### worked when nacos.core.auth.system.type=nacos
### The token expiration in seconds:
nacos.core.auth.plugin.nacos.token.expire.seconds=${NACOS_AUTH_TOKEN_EXPIRE_SECONDS:18000}
### The default token:
nacos.core.auth.plugin.nacos.token.secret.key=${NACOS_AUTH_TOKEN:}
### Turn on/off caching of auth information. By turning on this switch, the update of auth information would have a 15 seconds delay.
nacos.core.auth.caching.enabled=${NACOS_AUTH_CACHE_ENABLE:false}
nacos.core.auth.enable.userAgentAuthWhite=${NACOS_AUTH_USER_AGENT_AUTH_WHITE_ENABLE:false}
nacos.core.auth.server.identity.key=${NACOS_AUTH_IDENTITY_KEY:}
nacos.core.auth.server.identity.value=${NACOS_AUTH_IDENTITY_VALUE:}
## spring security config
### turn off security
nacos.security.ignore.urls=${NACOS_SECURITY_IGNORE_URLS:/,/error,/**/*.css,/**/*.js,/**/*.html,/**/*.map,/**/*.svg,/**/*.png,/**/*.ico,/console-fe/public/**,/v1/auth/**,/v1/console/health/**,/actuator/**,/v1/console/server/**}
# metrics for elastic search
management.metrics.export.elastic.enabled=false
management.metrics.export.influx.enabled=false
nacos.naming.distro.taskDispatchThreadCount=10
nacos.naming.distro.taskDispatchPeriod=200
nacos.naming.distro.batchSyncKeyCount=1000
nacos.naming.distro.initDataRatio=0.9
nacos.naming.distro.syncRetryDelay=5000
nacos.naming.data.warmup=true
nacos.console.ui.enabled=true
nacos.core.param.check.enabled=true

 

5.启动容器的docker-compose.yml也可转换成docker run 命令 如下代码(运行前需要把application.properties):

version: '3'
services:
  nacos:
    image: nacos/nacos-server:v2.4.3
    container_name: nacos
    environment:
      - MODE=standalone
      - SPRING_DATASOURCE_PLATFORM=mysql
      - MYSQL_SERVICE_HOST=mysql8
      - MYSQL_SERVICE_PORT=3306
      - MYSQL_SERVICE_DB_NAME=default_nacos
      - MYSQL_SERVICE_USER=root
      - MYSQL_SERVICE_PASSWORD=root
      - MYSQL_SERVICE_DB_PARAM=characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=GMT%2B8
    ports:
      - "8848:8848"
      - "9848:9848"
      - "9849:9849"
    volumes:
      - ./logs/:/home/nacos/logs
      - ./conf/:/home/nacos/conf
    restart: always
    networks:
      - cluster1
networks:
  cluster1:
    external: true

注:以上Nacos使用的MySQL是另外一个已启动的容器,两容器是在一个宿主机上,且在同一网络下

额外创建网络命令如下:

docker network create [自己定义的网络名称] 创建新网络网络驱动使用docker默认的
docker network ls 查看网络,看是否创建成功

//连接到创建的网络
docker network connect [自己定义的网络名称] [mysql的id]
docker network connect [自己定义的网络名称] [nacos的id]

//查看两容器是否在创建的网络中
docker network inspect [自己定义的网络名称]

 

标签:SERVICE,MYSQL,Nacos2.4,nacos,auth,server,MySQL,docker,Docker
From: https://www.cnblogs.com/xiaoluoye/p/18603384

相关文章

  • Mysql优化
    印象深刻的是刚进入一家公司,给了一个excel,里面的内容是线上慢查询的sql。因为sql太长过于复杂,然后就开启了顺着sql梳理业务的模式。这里只是单纯的优化sql,但出现系统慢的情况,IO优化应该按照以下思路进行。优化思路每个人理解的性能优化都不一样,对于数据库的性能优化,我理解的......
  • 《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose
    @目录二、高级篇(大厂进阶)5.Docker-compose容器编排5.1是什么5.2能干嘛5.3去哪下5.4Compose核心概念5.5Compose使用的三个步骤5.6Compose常用命令5.7Compose编排微服务5.7.1改造升级微服务工程docker_boot5.7.2不用Compose5.7.3swagger测试5.7.4上面成功了,有哪些问题?5.7.5......
  • Mysql中B+树
    结构特点节点结构:B+树是一种平衡多路查找树。它的非叶子节点只存储索引关键字和指向下一层节点的指针,所有的关键字都按照从小到大的顺序排列。叶子节点存储了真正的数据记录(或者是指向数据记录的指针),并且叶子节点之间通过指针形成一个有序链表,这种链表结构方便进行范围查询......
  • docker
    目录docker介绍安装和配置文件详解镜像与容器相关操作dockerFile指令dockerFile实现镜像自动化构建实现数据持久化实现容器间通信和网络docker-compose单机编排工具搭建harbor私有仓库docker介绍Docker的组成Docker主机(Host):一个物理机或虚拟机,用于运行Docker......
  • 【MySQL 进阶之路】索引失效的11种情况
    MySQL进阶之路:索引失效的11种情况在MySQL的查询优化中,索引是一项至关重要的技术,它能够大大提升数据检索的效率。本文将讨论这11种常见情况,帮助开发者更好地理解索引的使用及优化。图示1.使用不等式操作符(!=,<,>)例子:SELECT*FROMusersWHEREage!=30;原理:索......
  • 通过 Docker Compose 本地启动 zk 集群
    项目如果你想直接看代码,可以直接看我的git-docker-centos项目地址,最近发布了v1.2.0版本,readme已经非常详细了,包括项目的使用方式和需求规划本机环境基本只依赖Docker的安装,DockerDesktop的安装教程可参考我之前的博客-DockerDesktop安装方式和开发镜像分享,当然,更详......
  • Dockerfile构建demo
    Dockerfile模板如下:#基础镜像FROMopenjdk:8-jdk-slim#作者信息LABELmaintainer="xyqq"#设置工作目录WORKDIR/app#复制应用程序JAR文件到工作目录COPY*.jarapp.jar#暴露应用端口EXPOSE8080#设置运行环境变量ENVJAVA_OPTS=""#启动容器时执......
  • 实现MySQL数据归档一些常见的工具介绍及其优缺点
    下面是一些常见的工具和方法的介绍及其优缺点:pt-archiver‌介绍‌:pt-archiver是Percona-Toolkit工具集中的一个组件,主要用于对MySQL表数据进行归档和清除。它可以将数据归档到另一张表或者是一个文件中,并且在清除表数据的过程中不会影响OLTP事务的查询性能。优点‌:归档......
  • docker-compose部署Archery SQL审核工具
    下载安装包gitclonehttps://gitee.com/rtttte/Archery.git安装步骤cdsrc/docker-compose#.env文件修改,如果修改了mysql和redis的密码,env里也要更新,或者使用settings.py复写NGINX_PORT=9123DEBUG=trueDATABASE_URL=mysql://root:123456@mysql:3306/archeryCAC......
  • MySQL原理解析:MySQL的索引结构为什么使用B+树?
    前言在MySQL中,无论是Innodb还是MyIsam,都使用了B+树作索引结构(这里不考虑hash等其他索引)。本文将从最普通的二叉查找树开始,逐步说明各种树解决的问题以及面临的新问题,从而说明MySQL为什么选择B+树作为索引结构。一、二叉查找树(BST):不平衡二叉查找树(BST,BinarySearchTree......