当前位置:   article > 正文

【Docker】nacos集群搭建Nginx负载均衡_docker nacos nginx

docker nacos nginx

目录

一、mysql安装与基操

1.1 数据准备 

1.2 创建mysql与数据表 

二、Nacos集群部署

2.1 创建nacos及配置

2.2 创建Nginx容器


一、mysql安装与基操

1.1 数据准备 

  • 拉取mysql
docker pull mysql:5.7(版本)
  • 定义挂载目录
mkdir -p /mysql/{conf,data,script}
  •  配置my.cnf

my.cnf内容: 

  1. [mysqld]
  2. #Mysql服务的唯一编号 每个mysql服务Id需唯一
  3. server-id=1
  4. #服务端口号 默认3306
  5. port=3306
  6. #mysql安装根目录(default /usr)
  7. #basedir=/usr/local/mysql
  8. #mysql数据文件所在位置
  9. datadir=/var/lib/mysql
  10. #pid
  11. pid-file=/var/run/mysqld/mysqld.pid
  12. #设置socke文件所在目录
  13. socket=/var/lib/mysql/mysql.sock
  14. #设置临时目录
  15. #tmpdir=/tmp
  16. # 用户
  17. user=mysql
  18. # 允许访问的IP网段
  19. bind-address=0.0.0.0
  20. # 跳过密码登录
  21. #skip-grant-tables
  22. #主要用于MyISAM存储引擎,如果多台服务器连接一个数据库则建议注释下面内容
  23. #skip-external-locking
  24. #只能用IP地址检查客户端的登录,不用主机名
  25. #skip_name_resolve=1
  26. #事务隔离级别,默认为可重复读,mysql默认可重复读级别(此级别下可能参数很多间隙锁,影响性能)
  27. #transaction_isolation=READ-COMMITTED
  28. #数据库默认字符集,主流字符集支持一些特殊表情符号(特殊表情符占用4个字节)
  29. character-set-server=utf8mb4
  30. #数据库字符集对应一些排序等规则,注意要和character-set-server对应
  31. collation-server=utf8mb4_general_ci
  32. #设置client连接mysql时的字符集,防止乱码
  33. init_connect='SET NAMES utf8mb4'
  34. #是否对sql语句大小写敏感,1表示不敏感
  35. lower_case_table_names=1
  36. #最大连接数
  37. max_connections=400
  38. #最大错误连接数
  39. max_connect_errors=1000
  40. #TIMESTAMP如果没有显示声明NOT NULL,允许NULL值
  41. explicit_defaults_for_timestamp=true
  42. #SQL数据包发送的大小,如果有BLOB对象建议修改成1G
  43. max_allowed_packet=128M
  44. #MySQL连接闲置超过一定时间后(单位:秒)将会被强行关闭
  45. #MySQL默认的wait_timeout 值为8个小时, interactive_timeout参数需要同时配置才能生效
  46. interactive_timeout=1800
  47. wait_timeout=1800
  48. #内部内存临时表的最大值 ,设置成128M。
  49. #比如大数据量的group by ,order by时可能用到临时表,
  50. #超过了这个值将写入磁盘,系统IO压力增大
  51. tmp_table_size=134217728
  52. max_heap_table_size=134217728
  53. #禁用mysql的缓存查询结果集功能
  54. #后期根据业务情况测试决定是否开启
  55. #大部分情况下关闭下面两项
  56. #query_cache_size = 0
  57. #query_cache_type = 0
  58. #数据库错误日志文件
  59. #log-error=/var/log/mysqld.log
  60. #慢查询sql日志设置
  61. #slow_query_log=1
  62. #slow_query_log_file=/var/log/mysqld_slow.log
  63. #检查未使用到索引的sql
  64. log_queries_not_using_indexes=1
  65. #针对log_queries_not_using_indexes开启后,记录慢sql的频次、每分钟记录的条数
  66. log_throttle_queries_not_using_indexes=5
  67. #作为从库时生效,从库复制中如何有慢sql也将被记录
  68. log_slow_slave_statements=1
  69. #慢查询执行的秒数,必须达到此值可被记录
  70. long_query_time=8
  71. #检索的行数必须达到此值才可被记为慢查询
  72. min_examined_row_limit=100
  73. #mysql binlog日志文件保存的过期时间,过期后自动删除
  74. #expire_logs_days=5
  75. binlog_expire_logs_seconds=604800
  • 准备sql脚本

1.2 创建mysql与数据表 

创建mysql容器

  1. docker run \
  2. --name m1 \
  3. -v /mysql/conf/my.cnf:/etc/my.cnf \
  4. -v /mysql/data:/var/lib/mysql \
  5. -v /mysql/script:/script \
  6. --privileged=true \
  7. -e MYSQL_ROOT_PASSWORD=123456 \
  8. -d mysql/mysql-server:5.7

 执行sql脚本进入script文件下

查看数据表:

二、Nacos集群部署

2.1 创建nacos及配置

  • 拉取nacos容器(内存大约1G) 
docker nacos/nacos-server

  • 连接自定义网络

nacos与mysql不在同一个网络IP,将mysql连接到自定义网络(net)再连接到nacos 

 

  •  启动nacos集群模式(设置nacos启动参数)
  1. docker run -itd \
  2. -e PREFER_HOST_MODE=ip \
  3. -e MODE=cluster \
  4. -e NACOS_SERVERS="172.18.0.102:8848 172.18.0.103:8848" \
  5. -e SPRING_DATASOURCE_PLATFORM=mysql \
  6. -e MYSQL_SERVICE_HOST=m1 \
  7. -e MYSQL_SERVICE_PORT=3306 \
  8. -e MYSQL_SERVICE_DB_NAME=nacos \
  9. -e MYSQL_SERVICE_USER=root \
  10. -e MYSQL_SERVICE_PASSWORD=123456 \
  11. -p 8848:8848 \
  12. --name nacos01 \
  13. --net net \
  14. --ip 172.18.0.101 \
  15. --restart=always \
  16. nacos/nacos-server
  1. docker run -itd \
  2. -e PREFER_HOST_MODE=ip \
  3. -e MODE=cluster \
  4. -e NACOS_SERVERS="172.18.0.101:8848 172.18.0.103:8848" \
  5. -e SPRING_DATASOURCE_PLATFORM=mysql \
  6. -e MYSQL_SERVICE_HOST=m1 \
  7. -e MYSQL_SERVICE_PORT=3306 \
  8. -e MYSQL_SERVICE_DB_NAME=nacos \
  9. -e MYSQL_SERVICE_USER=root \
  10. -e MYSQL_SERVICE_PASSWORD=123456 \
  11. --name nacos02 \
  12. --net net \
  13. --ip 172.18.0.102 \
  14. --restart=always \
  15. nacos/nacos-server

  1. docker run -itd \
  2. -e PREFER_HOST_MODE=ip \
  3. -e MODE=cluster \
  4. -e NACOS_SERVERS="172.18.0.101:8848 172.18.0.102:8848" \
  5. -e SPRING_DATASOURCE_PLATFORM=mysql \
  6. -e MYSQL_SERVICE_HOST=m1 \
  7. -e MYSQL_SERVICE_PORT=3306 \
  8. -e MYSQL_SERVICE_DB_NAME=nacos \
  9. -e MYSQL_SERVICE_USER=root \
  10. -e MYSQL_SERVICE_PASSWORD=123456 \
  11. --name nacos03 \
  12. --net net \
  13. --ip 172.18.0.103 \
  14. --restart=always \
  15. nacos/nacos-server

如果出现 No DataSource set

  • 检查ip是否对应

  • 是否在同一网段下

  • 检查数据库名称

  • 检查root与密码

  • 检查数据库中是否存在对应的表(是否执行脚本)

 启动了三台:

2.2 创建Nginx容器

创建nginx配置文件: 

default.conf:

  1. upstream nacosList {
  2. server nacos01:8848 weight=1;
  3. server nacos02:8848 weight=1;
  4. server nacos03.:8848 weight=1;
  5. }
  6. server {
  7. listen 80;
  8. server_name www.zkingedu.com;
  9. location / {
  10. root /etc/nginx/html/;
  11. index index.html index.htm;
  12. }
  13. error_page 500 502 503 504 /50x.html;
  14. location = /50x.html {
  15. root /usr/share/nginx/html;
  16. }
  17. location /nacos {
  18. proxy_pass http://nacosList;
  19. }
  20. }

挂载nginx:

  1. docker run -itd \
  2. --name nginx01 \
  3. -v /soft/nginx/conf.d:/etc/nginx/conf.d \
  4. -p 80:80 \
  5. --net net \
  6. nginx

实现了负载均衡,只要哪个容器下线其他的容器就开始为它服务:

图解:

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/145398
推荐阅读
相关标签
  

闽ICP备14008679号