Centos8安装Docker

1.更新一下yum
  1. [root@VM-24-9-centos ~]# yum -y update
2.安装containerd.io
  1. # centos8默认使用podman代替docker,所以需要containerd.io
  2. [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
  3. # 安装一些其他依赖
  4. [root@VM-24-9-centos ~]# yum install -y yum-utils device-mapper-persistent-data lvm2
  5. [root@VM-24-9-centos ~]# yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
3.安装Docker
  1. [root@VM-24-9-centos ~]# yum install -y docker-ce
4.启动Docker
  1. # 启动docker
  2. [root@VM-24-9-centos ~]# systemctl start docker
  3. # 设置开机自启
  4. [root@VM-24-9-centos ~]# systemctl enable docker
5.设置容器开机自启
  1. [root@VM-16-7-centos ~]# docker update --restart=always 容器名
  2. --restart具体参数值详细信息:
  3. no:容器退出时,不重启容器
  4. on-failure:只有在非0状态退出时才从新启动容器
  5. always:无论退出状态是如何,都重启容器

Mysql8.0部署

1.拉取镜像
  1. [root@VM-24-9-centos ~]# docker pull mysql
  2. # 如需拉取置指定版本镜像加上:版本号即可
  3. [root@VM-24-9-centos ~]# docker pull mysql:7.6
1.创建本地文件用于挂载
  1. [root@VM-24-9-centos ~]# mkdir -p /data/mysql/data
  2. [root@VM-24-9-centos ~]# mkdir -p /data/mysql/conf
  3. [root@VM-24-9-centos ~]# mkdir -p /data/mysql/conf/conf.d
2.启动一个容器,将容器内的配置文件 /etc/mysql/my.cnf,copy到我们本地,用于默认配置文件
  1. # 启动一个容器用于复制配置文件
  2. [root@VM-24-9-centos ~]# docker run -d -p 3306:3306 --name mysqlone mysql:latest
  3. 07c314a5e57c3a3ca8ab8ffe5937b4fdb6c87a831b7e15666ee7266feb5af42a
  4. [root@VM-24-9-centos ~]# docker cp mysqlone:/etc/mysql/my.cnf /data/mysql/conf/
  5. # 停止并删除该容器
  6. [root@VM-24-9-centos ~]# docker stop mysqlone
  7. mysqlone
  8. [root@VM-24-9-centos ~]# docker rm mysqlone
  9. mysqlone
  10. # 查看配置文件是否复制成功
  11. [root@VM-24-9-centos ~]# cd /data/mysql/conf/
  12. [root@VM-24-9-centos conf]# ls
  13. my.cnf
3.使用本地配置文件挂载容器内的配置文件并挂载数据文件
  1. 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.写好配置文件
  1. [mysqld]
  2. pid-file = /var/run/mysqld/mysqld.pid
  3. socket = /var/run/mysqld/mysqld.sock
  4. datadir = /var/lib/mysql
  5. secure-file-priv= NULL
  6. # Custom config should go here
  7. !includedir /etc/mysql/conf.d/
  8. server-id=1
  9. log-bin=mysql-bin
  10. binlog-do-db=morin
  11. binlog-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主节点配置
  1. # 添加用于同步的数据库账号
  2. CREATE USER 'rootslave1'@'110.40.158.72' IDENTIFIED WITH mysql_native_password BY '123456';
  3. # 授权
  4. grant replication slave on *.* to 'rootslave1'@'110.40.158.72';
  5. # 刷新配置
  6. FLUSH PRIVILEGES;
  7. # 查询所有用
  8. select user,host from mysql.user;
  9. # 查询主节点状态
  10. show master status;
2.2从节点配置
  1. # 配置主从同步
  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;
  3. # 开启同步
  4. start slave;
  5. # 查看从节点状态
  6. show slave status;

注意事项:

  • 配置主从同步的 master_log_filemaster_log_pos参数是根据,主节点配置里的查询主节点状态命令查看的,这里的参数直接复制过来用
  • 开启同步之后查看从节点状态,必须保证 Salve_IO_Running Salve_SQL_Runing为 Yes,才能同步成功。为No的情况一般是前面说的两个字段的值不对

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

.Net6项目发布

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

Dockerfile文件内容如下:

  1. FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS base
  2. WORKDIR /app
  3. EXPOSE 8989
  4. FROM mcr.microsoft.com/dotnet/sdk:6.0 AS build
  5. WORKDIR /src
  6. COPY . .
  7. ENTRYPOINT ["dotnet", "x.API.dll"]
2.构建镜像
1.把发布文件(包括Dockerfile文件)复制到Centos服务器中,然后在当前目录构建镜像
  1. [root@VM-0-17-centos conf]# docker build -t 镜像名:版本号 .

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

3.构建容器,并把配置文件挂载出来
  1. [root@VM-0-17-centos conf]# docker run -d -p 9999:9999 -v /usr/local/release/project/appsettings.json:/src/appsettings.json --name projectapi project:1.0

Sqlserver部署

前提条件

  • 服务器需要大于2G内存。如果不够则可能无法正常启动
1.获取 sqlserver 镜像
  1. [root@VM-24-9-centos ~]# docker pull mcr.microsoft.com/mssql/server:2019-latest
2.创建数据文件进行数据挂载
  1. [root@VM-24-9-centos ~]# mkdir -p /data/sqlserver/data
  2. # 修改目录权限,不修改权限会报错
  3. [root@VM-24-9-centos ~]# chown -R 10001:0 /data/sqlserver/data/
3.运行容器
  1. [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.拉取镜像及批量生成配置文件
  1. # 拉取镜像
  2. [root@VM-24-9-centos ~]# docker pull elasticsearch:7.2.0
  3. # 生成配置文件及目录
  4. for port in $(seq 1 6); \
  5. do \
  6. mkdir -p /data/es/node-${port}/conf
  7. mkdir -p /data/es/node-${port}/data
  8. mkdir -p /data/es/node-${port}/plugins
  9. chmod 777 /data/es/node-${port}/data
  10. touch /data/es/node-${port}/conf/es.yml
  11. cat << EOF >>/data/es/node-${port}/conf/es.yml
  12. cluster.name: lbj
  13. node.name: node${port}
  14. node.master: true
  15. node.data: true
  16. bootstrap.memory_lock: false
  17. network.host: 0.0.0.0
  18. http.port: 920${port}
  19. transport.tcp.port: 930${port}
  20. discovery.seed_hosts: ["x.x.x.x:9301","x.x.x.x:9302","x.x.x.x:9303","x.x.x.x:9304"]
  21. cluster.initial_master_nodes: ["node1","node2","node3","node4"]
  22. cluster.routing.allocation.cluster_concurrent_rebalance: 32
  23. cluster.routing.allocation.node_concurrent_recoveries: 32
  24. cluster.routing.allocation.node_initial_primaries_recoveries: 32
  25. http.cors.enabled: true
  26. http.cors.allow-origin: "*"
  27. discovery.zen.minimum_master_nodes: 2
  28. EOF
  29. done;
2.批量创建容器及查看集群信息
  1. # 批量创建容器
  2. for port in $(seq 1 4); \
  3. do \
  4. docker run -e ES_JAVA_OPTS="-Xms512m -Xmx512m" \
  5. -d -p 920${port}:920${port} -p 930${port}:930${port} \
  6. -e ES_MIN_MEM=128m \
  7. -e ES_MAX_MEM=2048m \
  8. -v /data/es/node-${port}/conf/es.yml:/usr/share/elasticsearch/config/elasticsearch.yml \
  9. -v /data/es/node-${port}/data/:/usr/share/elasticsearch/data/ \
  10. -v /data/es/node-${port}/plugins/:/usr/share/elasticsearch/plugins \
  11. --name ES-${port} \
  12. elasticsearch:7.2.0
  13. done
  14. # 查看单个节点信息
  15. [root@VM-24-9-centos ~]# curl http://x.x.x.x:9201/
  16. {
  17. "name" : "node1",
  18. "cluster_name" : "lbj",
  19. "cluster_uuid" : "Vjb7cu6fQ6y2-ZWk0YGIiQ",
  20. "version" : {
  21. "number" : "7.2.0",
  22. "build_flavor" : "default",
  23. "build_type" : "docker",
  24. "build_hash" : "508c38a",
  25. "build_date" : "2019-06-20T15:54:18.811730Z",
  26. "build_snapshot" : false,
  27. "lucene_version" : "8.0.0",
  28. "minimum_wire_compatibility_version" : "6.8.0",
  29. "minimum_index_compatibility_version" : "6.0.0-beta1"
  30. },
  31. "tagline" : "You Know, for Search"
  32. }
  33. # 查看集群信息
  34. [root@VM-24-9-centos ~]# curl http://x.x.x.x:9201/_cat/nodes?pretty
  35. 172.17.0.2 37 97 0 0.00 0.00 0.08 mdi * node1
  36. 172.17.0.4 35 97 0 0.00 0.00 0.08 mdi - node3
  37. 172.17.0.3 39 97 1 0.00 0.00 0.08 mdi - node2
  38. 172.17.0.6 34 97 1 0.00 0.00 0.08 mdi - node4

部署ElasticSearch-Head

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

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

Docker部署 Mysql .Net6等容器的更多相关文章

  1. docker 部署mysql tomcat时 在root@localhost~下——-——docker exec -it 容器名 /bin/bash 报错

    在docker部署mysql时 报错 找不到 容器不自动启动  , docker start 容器名  也没有效果 多次尝试发现 原因是创建容器时在 下面创建的 更改为下创建 问题解决

  2. Docker 部署mysql

    目录 Docker 部署mysql 步骤 1.查找 Docker Hub 上的 MySQL 镜像 2.docker pull mysql 拉取镜像 3.运行容器 4.查看容器启动情况 使用命令备注 D ...

  3. docker(部署常见应用):docker部署mysql

    上节回顾:docker(部署常见应用):docker部署nginx docker部署mysql:5.7.26 # 下载镜像 docker pull mysql: # 查看镜像 docker image ...

  4. docker部署mysql Navicat远程连接

    docker部署mysql Navicat远程连接 docker search mysql   查看mysql镜像(是去dockerHub网站搜素镜像,遇到问题可以去该网站查看官方文档,纯英文文档估计 ...

  5. Docker:Docker部署mysql数据库

    docker部署mysql : 8.0 1.在宿主机创建mysql挂载目录 #创建目录 mkdir /home/mysql/conf mkdir /home/mysql/logs mkdir /hom ...

  6. springboot多数据源配合docker部署mysql主从实现读写分离

    本篇主要有两部分: 1.使用docker部署mysql主从 实现主从复制 2.springboot项目多数据源配置,实现读写分离 一.使用docker部署mysql主从 实现主从复制 此次使用的是wi ...

  7. Docker部署mysql 5.7

    Docker部署mysql 5.7 准备工作 在CentOS或者Linux创建部署目录,用于存放容器的配置和MySQL数据:目的是当重装或者升级容器时,配置文件和数据不会丢失.执行以下命令: a.创建 ...

  8. Centos7借助docker部署mysql,提供远程链接服务

    Centos7 借助docker部署mysql,并提供远程连接服务 安装docker 运行docker 注意安装docker和运行docker的步骤很简单,可以参考我学习docker的笔记 docke ...

  9. Docker部署MySQL容器

    从仓库下载镜像 sudo docker pull mysql:5.7   创建容器 docker run --name="mysql" \ -p 3306:3306 \ -v /U ...

随机推荐

  1. C++ 可变数组实现

    话不多说,直接上代码,看注释 template<class T> // 支持传入泛型,但string这种可变长度的类型还不支持 class Array { int mSize = 0, m ...

  2. JS中call,apply,bind的区别

    1.关于this对象的指向,请看如下代码 var name = 'jack'; var age = 18; var obj = { name:'mary', objAge:this.age, myFu ...

  3. 使用CEF(四)— 在QT中集成CEF(1):基本集成

    QT作为C++下著名的跨平台软件开发框架,实现了一套代码可以在所有的操作系统.平台和屏幕类型上部署.我们前几篇文章讲解了如何构建一款基于CEF的简单的样例,但这些样例的GUI都是使用的原生的或者是控件 ...

  4. 打开属性页,分别在Debug和Release下将其配置类型改为:静态库(.lib);

    右键工程->属性 配置类型里面的下拉菜单选择静态库

  5. windows中抓包命令,以及保存为多个文件的方法

    本文主要介绍windows中抓包命令,以及保存为多个文件的方法 说一说保存为多个文件存储数据包这个问题的由来,一般如果长时间抓包,有可能需要等上几个小时,因为这个时候抓包的内容都是存放在内存中的,几个 ...

  6. SONiC架构分析

    目录 系统架构 设计原则 核心组件 SWSS 容器 syncd 容器 网络应用容器 内部通信模型 SubscriberStateTable NotificationProducer/Consumer ...

  7. 手把手教你写hexo博客

    市面上现在有各种博客框架,本博客教大家的是Hexo博客框架,目前比较火.搭建博客中遇到各种各样问题,网上方案也比较成熟. 一.搭建环境 安装 git 安装 node.js 安装 Hexo npm in ...

  8. 网页常用的css特效让互动留住客户

    一般网站如果制作按钮,多做一些互动,可以让客户获得更好的体验. 例如鼠标滑过按钮,让背景颜色从左往右滑出来(或者从右往左都可以): <a target="_blank" hr ...

  9. Head First Python 代码和实例下载

    http://python.itcarlow.ie/resources.html

  10. 【死磕 NIO】— Reactor 模式就一定意味着高性能吗?

    大家好,我是大明哥,我又来了. 为什么是 Reactor 一般所有的网络服务,一般分为如下几个步骤: 读请求(read request) 读解析(read decode) 处理程序(process s ...