我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Docker如何部署Mysql,.Net6,Sqlserver等容器

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Docker如何部署Mysql,.Net6,Sqlserver等容器

这篇文章主要介绍了Docker如何部署Mysql,.Net6,Sqlserver等容器,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

Centos8安装Docker

1.更新一下yum

[root@VM-24-9-centos ~]# yum -y update

2.安装containerd.io

# centos8默认使用podman代替docker,所以需要containerd.io[root@VM-24-9-centos ~]# yum install https://download.docker.com/linux/fedora/30/x86_64/stable/Packages/containerd.io-1.2.6-3.3.fc30.x86_64.rpm -y# 安装一些其他依赖[root@VM-24-9-centos ~]# yum install -y yum-utils device-mapper-persistent-data lvm2[root@VM-24-9-centos ~]# yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

3.安装Docker

[root@VM-24-9-centos ~]# yum install -y docker-ce

4.启动Docker

# 启动docker[root@VM-24-9-centos ~]# systemctl start docker# 设置开机自启[root@VM-24-9-centos ~]# systemctl enable docker

5.设置容器开机自启

[root@VM-16-7-centos ~]# docker update --restart=always 容器名--restart具体参数值详细信息:no:容器退出时,不重启容器  on-failure:只有在非0状态退出时才从新启动容器  always:无论退出状态是如何,都重启容器

Mysql8.0部署

1.拉取镜像

[root@VM-24-9-centos ~]# docker pull mysql# 如需拉取置指定版本镜像加上:版本号即可[root@VM-24-9-centos ~]# docker pull mysql:7.6

2.创建本地文件用于挂载

[root@VM-24-9-centos ~]# mkdir -p /data/mysql/data[root@VM-24-9-centos ~]# mkdir -p /data/mysql/conf[root@VM-24-9-centos ~]# mkdir -p /data/mysql/conf/conf.d

3.启动一个容器,将容器内的配置文件 /etc/mysql/my.cnf,copy到我们本地,用于默认配置文件

# 启动一个容器用于复制配置文件[root@VM-24-9-centos ~]# docker run -d -p 3306:3306 --name mysqlone mysql:latest07c314a5e57c3a3ca8ab8ffe5937b4fdb6c87a831b7e15666ee7266feb5af42a[root@VM-24-9-centos ~]# docker cp mysqlone:/etc/mysql/my.cnf /data/mysql/conf/# 停止并删除该容器[root@VM-24-9-centos ~]# docker stop mysqlonemysqlone[root@VM-24-9-centos ~]# docker rm mysqlonemysqlone# 查看配置文件是否复制成功[root@VM-24-9-centos ~]# cd /data/mysql/conf/[root@VM-24-9-centos conf]# lsmy.cnf

4.使用本地配置文件挂载容器内的配置文件并挂载数据文件

docker run -d -p 3306:3306 --name mysqlmaster  -e MYSQL_ROOT_PASSWORD='jing1996' -v /data/mysql/conf:/etc/mysql -v /data/mysql/data:/var/lib/mysql mysql

Mysql8.0部署主从复制

1.写好配置文件

[mysqld]pid-file        = /var/run/mysqld/mysqld.pidsocket          = /var/run/mysqld/mysqld.sockdatadir         = /var/lib/mysqlsecure-file-priv= NULL# Custom config should go here!includedir /etc/mysql/conf.d/server-id=1log-bin=mysql-binbinlog-do-db=morinbinlog-ignore-db=mysql
  • server-id :服务器Id,不能相同。

  • log-bin:二进制文件存放路径,非必须,mysql8后默认存放/var/lib/mysql这里

  • binlog-do-db:需要同步的数据库,如果有多个以空格隔开db1 db2 db3

  • binlog-ignore-db:不需要同步的数据库 如果有多个以空格隔开db1 db2 db3

2.节点配置

2.1主节点配置
# 添加用于同步的数据库账号CREATE USER 'rootslave1'@'110.40.158.72' IDENTIFIED WITH mysql_native_password BY '123456';# 授权grant replication slave on *.* to 'rootslave1'@'110.40.158.72';# 刷新配置FLUSH PRIVILEGES;# 查询所有用select user,host from mysql.user;# 查询主节点状态show master status;
2.2从节点配置
# 配置主从同步change master to master_host='x.x.x.x',master_user='rootslave1',master_password='123456',master_log_file='mysql-bin.000003',master_log_pos=2384;# 开启同步start slave;# 查看从节点状态show slave status;

注意事项:

  • 配置主从同步的 master_log_file和master_log_pos参数是根据,主节点配置里的查询主节点状态命令查看的,这里的参数直接复制过来用

  • 开启同步之后查看从节点状态,必须保证 Salve_IO_Running 和 Salve_SQL_Runing为 Yes,才能同步成功。为No的情况一般是前面说的两个字段的值不对

如果需要同步的数据库在主库中已存在,是不会主动同步的,建议保留好数据删除数据库从建,就会自动同步到从库了

.Net6项目发布

1.在VS中发布项目,并编写好Dockerfile文件

Dockerfile文件内容如下:

FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS baseWORKDIR /appEXPOSE 8989FROM mcr.microsoft.com/dotnet/sdk:6.0 AS buildWORKDIR /class="lazy" data-srcCOPY . .ENTRYPOINT ["dotnet", "x.API.dll"]

2.构建镜像

把发布文件(包括Dockerfile文件)复制到Centos服务器中,然后在当前目录构建镜像

[root@VM-0-17-centos conf]# docker build -t 镜像名:版本号 .

eg:注意最后有个小点 . ,这个点指的是Dockerfile文件所在的目录,如果在当前目录则为 . ,在其他目录得输入完整的目录路径

3.构建容器,并把配置文件挂载出来

[root@VM-0-17-centos conf]# docker run -d -p 9999:9999 -v /usr/local/release/project/appsettings.json:/class="lazy" data-src/appsettings.json --name projectapi project:1.0

Sqlserver部署

前提条件:

  • 服务器需要大于2G内存。如果不够则可能无法正常启动

1.获取 sqlserver 镜像

[root@VM-24-9-centos ~]# docker pull mcr.microsoft.com/mssql/server:2019-latest

2.创建数据文件进行数据挂载

[root@VM-24-9-centos ~]# mkdir -p /data/sqlserver/data# 修改目录权限,不修改权限会报错[root@VM-24-9-centos ~]# chown -R 10001:0 /data/sqlserver/data/

3.运行容器

[root@VM-24-9-centos sqlserverdata]# docker run -d -p 1433:1433 -e 'ACCEPT_EULA=Y' -e 'SA_PASSWORD=sa123456.?' -v /data/sqlserver/data:/var/opt/mssql --name sqlserver mcr.microsoft.com/mssql/server:2019-latest

注意事项:

  • ACCEPT_EULA=Y的意思是同意许可协议,必选

  • MSSQL_SA_PASSWORD为密码,要求是最少8位的强密码,要有大写字母,小写字母,数字以及特殊符号,不然docker启动sqlserver容器后过几秒就停止了

  • 使用navcat连接时,端口号跟IP地址之间是使用的逗号分割,而不是冒号

  • 创建的数据挂载目录需修改权限

ElasticSearch集群部署

部署ElasticSearch

1.拉取镜像及批量生成配置文件
# 拉取镜像[root@VM-24-9-centos ~]# docker pull elasticsearch:7.2.0# 生成配置文件及目录for port in $(seq 1 6); \do \mkdir -p /data/es/node-${port}/confmkdir -p /data/es/node-${port}/datamkdir -p /data/es/node-${port}/pluginschmod 777 /data/es/node-${port}/datatouch /data/es/node-${port}/conf/es.ymlcat << EOF >>/data/es/node-${port}/conf/es.ymlcluster.name: lbjnode.name: node${port}node.master: truenode.data: truebootstrap.memory_lock: falsenetwork.host: 0.0.0.0http.port: 920${port}transport.tcp.port: 930${port}discovery.seed_hosts: ["x.x.x.x:9301","x.x.x.x:9302","x.x.x.x:9303","x.x.x.x:9304"]cluster.initial_master_nodes: ["node1","node2","node3","node4"]cluster.routing.allocation.cluster_concurrent_rebalance: 32cluster.routing.allocation.node_concurrent_recoveries: 32cluster.routing.allocation.node_initial_primaries_recoveries: 32http.cors.enabled: truehttp.cors.allow-origin: "*"discovery.zen.minimum_master_nodes: 2EOFdone;
2.批量创建容器及查看集群信息
# 批量创建容器for port in $(seq 1 4); \do \docker run -e ES_JAVA_OPTS="-Xms512m -Xmx512m" \-d -p 920${port}:920${port} -p 930${port}:930${port} \-e ES_MIN_MEM=128m \-e ES_MAX_MEM=2048m \-v /data/es/node-${port}/conf/es.yml:/usr/share/elasticsearch/config/elasticsearch.yml \-v /data/es/node-${port}/data/:/usr/share/elasticsearch/data/ \-v /data/es/node-${port}/plugins/:/usr/share/elasticsearch/plugins  \--name ES-${port} \elasticsearch:7.2.0done# 查看单个节点信息[root@VM-24-9-centos ~]# curl http://x.x.x.x:9201/{  "name" : "node1",  "cluster_name" : "lbj",  "cluster_uuid" : "Vjb7cu6fQ6y2-ZWk0YGIiQ",  "version" : {    "number" : "7.2.0",    "build_flavor" : "default",    "build_type" : "docker",    "build_hash" : "508c38a",    "build_date" : "2019-06-20T15:54:18.811730Z",    "build_snapshot" : false,    "lucene_version" : "8.0.0",    "minimum_wire_compatibility_version" : "6.8.0",    "minimum_index_compatibility_version" : "6.0.0-beta1"  },  "tagline" : "You Know, for Search"}# 查看集群信息[root@VM-24-9-centos ~]# curl http://x.x.x.x:9201/_cat/nodes?pretty172.17.0.2 37 97 0 0.00 0.00 0.08 mdi * node1172.17.0.4 35 97 0 0.00 0.00 0.08 mdi - node3172.17.0.3 39 97 1 0.00 0.00 0.08 mdi - node2172.17.0.6 34 97 1 0.00 0.00 0.08 mdi - node4

部署ElasticSearch-Head

ElasticSearch-Head是一个管理界面,可以查看ElasticSearch相关信息

1.拉取ElasticSearch-Head镜像
[root@VM-24-9-centos ~]#  docker pull mobz/elasticsearch-head:5
2.运行ElasticSearch-Head容器
# 创建容器[root@VM-24-9-centos ~]# docker run -d --name es_admin -p 9100:9100 mobz/elasticsearch-head:5# pc端访问 IP:9100 即可用管理工具查看集群信息了

感谢你能够认真阅读完这篇文章,希望小编分享的“Docker如何部署Mysql,.Net6,Sqlserver等容器”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Docker如何部署Mysql,.Net6,Sqlserver等容器

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Docker如何部署Mysql,.Net6,Sqlserver等容器

这篇文章主要介绍了Docker如何部署Mysql,.Net6,Sqlserver等容器,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Centos8安装Docker1.更新一下
2023-06-22

如何部署.Net6项目到docker

这篇文章主要介绍“如何部署.Net6项目到docker”,在日常操作中,相信很多人在如何部署.Net6项目到docker问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何部署.Net6项目到docker”的疑
2023-06-22

Docker容器如何部署consul

小编给大家分享一下Docker容器如何部署consul,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Consul简介Consul 是一个支持多数据中心分布式高可用
2023-06-29

如何在docker容器中部署应用

本篇内容介绍了“如何在docker容器中部署应用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一个简单的Hello World应用。1.1
2023-06-02

如何在docker容器中部署Web项目

小编给大家分享一下如何在docker容器中部署Web项目,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!系统选用Centos或者Ubuntu都可以。 大致步骤:安装
2023-06-04

docker中如何部署mysql集群

在Docker中部署MySQL集群可以使用Docker Compose来管理多个MySQL容器,并使用MySQL Router来实现负载均衡和故障转移。以下是一个简单的示例:创建一个名为docker-compose.yml的文件,并在其中定
docker中如何部署mysql集群
2024-04-09

Docker如何部署mysql一主一从

这篇文章将为大家详细讲解有关Docker如何部署mysql一主一从,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。下载镜像选择MySQL镜像docker search mysql下载MySQL5.7镜像do
2023-06-15

如何使用Docker Compose快速部署多容器服务

小编给大家分享一下如何使用Docker Compose快速部署多容器服务,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!1 什么是Docker Compose前面我们使用 Docker 的时候,定义 Dockerfile 文
2023-06-29

如何使用Docker部署mysql数据库

今天小编给大家分享一下如何使用Docker部署mysql数据库的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、检查系统版本
2023-07-05

如何利用AWS的EC2技术部署服务器的Docker容器

这篇文章主要介绍“如何利用AWS的EC2技术部署服务器的Docker容器 ”,在日常操作中,相信很多人在如何利用AWS的EC2技术部署服务器的Docker容器 问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如
2023-06-10

Docker容器化部署Nginx的详细步骤与最佳实践(如何在Docker中高效部署Nginx服务?)

本文提供了详细步骤和最佳实践,指导如何将Nginx部署为Docker容器。步骤包括创建镜像、运行容器、配置Nginx以及管理容器。最佳实践建议使用最新版本、自定义配置、启用日志记录、使用反向代理以及监控容器。此外,本文还强调了安全容器的重要性,并建议定期备份和更新。
Docker容器化部署Nginx的详细步骤与最佳实践(如何在Docker中高效部署Nginx服务?)
2024-04-02

Docker安装Nginx并部署及MySQL容器构建全过程

本指南详细介绍了在Docker环境中安装Nginx并部署MySQL容器的步骤。从安装Docker开始,逐步讲解了运行Nginx容器、构建MySQL镜像和运行MySQL容器。还包括连接到MySQL、创建数据库和用户的说明。最后,指南提供了配置Nginx反向代理MySQL容器的步骤,并指导读者进行测试。希望这篇指南对读者部署自己的Docker容器有所帮助,并让他们了解使用Docker管理基础设施的优势。
Docker安装Nginx并部署及MySQL容器构建全过程
2024-04-02

docker如何进入mysql容器

要进入MySQL容器,可以使用以下命令:docker exec -it bash其中, 是 MySQL 容器的 ID。可以使用以下命令来查看容器的 ID:docker ps然后找
docker如何进入mysql容器
2024-05-07

Docker容器化Nginx的自动化构建与部署(如何实现Nginx在Docker中的自动化构建与部署?)

本文介绍了使用Docker自动化Nginx构建和部署的详细步骤。通过创建Dockerfile、使用DockerCompose定义服务、运行持续集成和部署(CI/CD)管道,可以实现Nginx在Docker容器中的自动化构建和部署。该方法提供了自动化、一致性、可移植性和可扩展性,从而简化应用程序开发和部署,提高效率和可靠性。
Docker容器化Nginx的自动化构建与部署(如何实现Nginx在Docker中的自动化构建与部署?)
2024-04-02

编程热搜

目录