欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2021年12月22日 11:50:45   作者:缺水的鯨魚  
這篇文章介紹了Docker部署Mysql,.Net6,Sqlserver等容器的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

Centos8安裝Docker

1.更新一下yum

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

2.安裝containerd.io

# centos8默認(rèn)使用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.啟動(dòng)Docker

# 啟動(dòng)docker
[root@VM-24-9-centos ~]# systemctl start docker
# 設(shè)置開機(jī)自啟
[root@VM-24-9-centos ~]# systemctl enable docker

5.設(shè)置容器開機(jī)自啟

[root@VM-16-7-centos ~]# docker update --restart=always 容器名
--restart具體參數(shù)值詳細(xì)信息:
	no:容器退出時(shí),不重啟容器
  on-failure:只有在非0狀態(tài)退出時(shí)才從新啟動(dòng)容器
  always:無(wú)論退出狀態(tài)是如何,都重啟容器

Mysql8.0部署

1.拉取鏡像

[root@VM-24-9-centos ~]# docker pull mysql
# 如需拉取置指定版本鏡像加上:版本號(hào)即可
[root@VM-24-9-centos ~]# docker pull mysql:7.6

2.創(chuàng)建本地文件用于掛載

[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.啟動(dòng)一個(gè)容器,將容器內(nèi)的配置文件 /etc/mysql/my.cnf,copy到我們本地,用于默認(rèn)配置文件

# 啟動(dòng)一個(gè)容器用于復(fù)制配置文件
[root@VM-24-9-centos ~]# docker run -d -p 3306:3306 --name mysqlone mysql:latest
07c314a5e57c3a3ca8ab8ffe5937b4fdb6c87a831b7e15666ee7266feb5af42a
[root@VM-24-9-centos ~]# docker cp mysqlone:/etc/mysql/my.cnf /data/mysql/conf/

# 停止并刪除該容器
[root@VM-24-9-centos ~]# docker stop mysqlone
mysqlone
[root@VM-24-9-centos ~]# docker rm mysqlone
mysqlone

# 查看配置文件是否復(fù)制成功
[root@VM-24-9-centos ~]# cd /data/mysql/conf/
[root@VM-24-9-centos conf]# ls
my.cnf

4.使用本地配置文件掛載容器內(nèi)的配置文件并掛載數(shù)據(jù)文件

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部署主從復(fù)制

1.寫好配置文件

[mysqld]
pid-file        = /var/run/mysqld/mysqld.pid
socket          = /var/run/mysqld/mysqld.sock
datadir         = /var/lib/mysql
secure-file-priv= NULL

# Custom config should go here
!includedir /etc/mysql/conf.d/
server-id=1
log-bin=mysql-bin
binlog-do-db=morin
binlog-ignore-db=mysql
  • server-id :服務(wù)器Id,不能相同。
  • log-bin:二進(jìn)制文件存放路徑,非必須,mysql8后默認(rèn)存放/var/lib/mysql這里
  • binlog-do-db:需要同步的數(shù)據(jù)庫(kù),如果有多個(gè)以空格隔開db1 db2 db3
  • binlog-ignore-db:不需要同步的數(shù)據(jù)庫(kù) 如果有多個(gè)以空格隔開db1 db2 db3

2.節(jié)點(diǎn)配置

2.1主節(jié)點(diǎn)配置

# 添加用于同步的數(shù)據(jù)庫(kù)賬號(hào)
CREATE USER 'rootslave1'@'110.40.158.72' IDENTIFIED WITH mysql_native_password BY '123456';
# 授權(quán)
grant replication slave on *.* to 'rootslave1'@'110.40.158.72';
# 刷新配置
FLUSH PRIVILEGES;
# 查詢所有用
select user,host from mysql.user;
# 查詢主節(jié)點(diǎn)狀態(tài)
show master status;

2.2從節(jié)點(diǎn)配置

# 配置主從同步
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;
# 查看從節(jié)點(diǎn)狀態(tài)
show slave status;

注意事項(xiàng):

  • 配置主從同步的 master_log_file和master_log_pos參數(shù)是根據(jù),主節(jié)點(diǎn)配置里的查詢主節(jié)點(diǎn)狀態(tài)命令查看的,這里的參數(shù)直接復(fù)制過來用
  • 開啟同步之后查看從節(jié)點(diǎn)狀態(tài),必須保證 Salve_IO_Running 和 Salve_SQL_Runing為 Yes,才能同步成功。為No的情況一般是前面說的兩個(gè)字段的值不對(duì)

如果需要同步的數(shù)據(jù)庫(kù)在主庫(kù)中已存在,是不會(huì)主動(dòng)同步的,建議保留好數(shù)據(jù)刪除數(shù)據(jù)庫(kù)從建,就會(huì)自動(dòng)同步到從庫(kù)了

.Net6項(xiàng)目發(fā)布

1.在VS中發(fā)布項(xiàng)目,并編寫好Dockerfile文件

Dockerfile文件內(nèi)容如下:

FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS base
WORKDIR /app
EXPOSE 8989

FROM mcr.microsoft.com/dotnet/sdk:6.0 AS build
WORKDIR /src
COPY . .

ENTRYPOINT ["dotnet", "x.API.dll"]

2.構(gòu)建鏡像

把發(fā)布文件(包括Dockerfile文件)復(fù)制到Centos服務(wù)器中,然后在當(dāng)前目錄構(gòu)建鏡像

[root@VM-0-17-centos conf]# docker build -t 鏡像名:版本號(hào) .

eg:注意最后有個(gè)小點(diǎn) . ,這個(gè)點(diǎn)指的是Dockerfile文件所在的目錄,如果在當(dāng)前目錄則為 . ,在其他目錄得輸入完整的目錄路徑

3.構(gòu)建容器,并把配置文件掛載出來

[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部署

前提條件:

  • 服務(wù)器需要大于2G內(nèi)存。如果不夠則可能無(wú)法正常啟動(dòng)

1.獲取 sqlserver 鏡像

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

2.創(chuàng)建數(shù)據(jù)文件進(jìn)行數(shù)據(jù)掛載

[root@VM-24-9-centos ~]# mkdir -p /data/sqlserver/data

# 修改目錄權(quán)限,不修改權(quán)限會(huì)報(bào)錯(cuò)
[root@VM-24-9-centos ~]# chown -R 10001:0 /data/sqlserver/data/

3.運(yùn)行容器

[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

注意事項(xiàng):

  • ACCEPT_EULA=Y的意思是同意許可協(xié)議,必選
  • MSSQL_SA_PASSWORD為密碼,要求是最少8位的強(qiáng)密碼,要有大寫字母,小寫字母,數(shù)字以及特殊符號(hào),不然docker啟動(dòng)sqlserver容器后過幾秒就停止了
  • 使用navcat連接時(shí),端口號(hào)跟IP地址之間是使用的逗號(hào)分割,而不是冒號(hào)
  • 創(chuàng)建的數(shù)據(jù)掛載目錄需修改權(quán)限

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}/conf
mkdir -p /data/es/node-${port}/data
mkdir -p /data/es/node-${port}/plugins
chmod 777 /data/es/node-${port}/data
touch /data/es/node-${port}/conf/es.yml
cat << EOF >>/data/es/node-${port}/conf/es.yml
cluster.name: lbj
node.name: node${port}
node.master: true
node.data: true
bootstrap.memory_lock: false
network.host: 0.0.0.0
http.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: 32
cluster.routing.allocation.node_concurrent_recoveries: 32
cluster.routing.allocation.node_initial_primaries_recoveries: 32
http.cors.enabled: true
http.cors.allow-origin: "*"
discovery.zen.minimum_master_nodes: 2
EOF
done;

2.批量創(chuàng)建容器及查看集群信息

# 批量創(chuàng)建容器
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.0
done

# 查看單個(gè)節(jié)點(diǎn)信息
[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?pretty
172.17.0.2 37 97 0 0.00 0.00 0.08 mdi * node1
172.17.0.4 35 97 0 0.00 0.00 0.08 mdi - node3
172.17.0.3 39 97 1 0.00 0.00 0.08 mdi - node2
172.17.0.6 34 97 1 0.00 0.00 0.08 mdi - node4

部署ElasticSearch-Head

?ElasticSearch-Head是一個(gè)管理界面,可以查看ElasticSearch相關(guān)信息

1.拉取ElasticSearch-Head鏡像

[root@VM-24-9-centos ~]#  docker pull mobz/elasticsearch-head:5

2.運(yùn)行ElasticSearch-Head容器

# 創(chuàng)建容器
[root@VM-24-9-centos ~]# docker run -d --name es_admin -p 9100:9100 mobz/elasticsearch-head:5

# pc端訪問 IP:9100 即可用管理工具查看集群信息了

到此這篇關(guān)于Docker部署Mysql,.Net6,Sqlserver等容器的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 使用 Docker 在 Ubuntu 上部署 FTP 服務(wù)器的步驟

    使用 Docker 在 Ubuntu 上部署 FTP 服務(wù)器

    本文詳細(xì)介紹了如何在Ubuntu系統(tǒng)上通過Docker部署FTP服務(wù)器的步驟,包括安裝Docker、拉取vsftpd鏡像以及運(yùn)行FTP容器等,通過這些步驟,用戶可以在提供的免費(fèi)云服務(wù)器上快速搭建起一個(gè)安全高效的FTP服務(wù),適合小型項(xiàng)目或個(gè)人使用,感興趣的朋友跟隨小編一起看看吧
    2024-10-10
  • ubuntu vps安裝docker報(bào)錯(cuò):Cannot connect to the Docker daemon at unix:///var/run/docker.sock.問題解決

    ubuntu vps安裝docker報(bào)錯(cuò):Cannot connect to t

    這篇文章主要介紹了解決ubuntu vps安裝docker時(shí)報(bào)錯(cuò):Cannot connect to the Docker daemon at unix:///var/run/docker.sock.問題的相關(guān)資料,文中介紹非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-04-04
  • 群暉NAS利用Docker容器搭建KMS激活服務(wù)器實(shí)現(xiàn)激活windows系統(tǒng)和office(操作步驟)

    群暉NAS利用Docker容器搭建KMS激活服務(wù)器實(shí)現(xiàn)激活windows系統(tǒng)和office(操作步驟)

    本文跟大家分享一下如何利用群暉NAS的Docker容器套件搭建KMS服務(wù)器,并演示如何利用我們自己的KMS服務(wù)器激活Windows操作系統(tǒng)與Microsoft Office,感興趣的朋友跟隨小編一起看看吧
    2021-05-05
  • Docker設(shè)置獲取環(huán)境變量的方法實(shí)現(xiàn)

    Docker設(shè)置獲取環(huán)境變量的方法實(shí)現(xiàn)

    本文主要介紹了Docker設(shè)置獲取環(huán)境變量的方法實(shí)現(xiàn),包含設(shè)置環(huán)境變量到使用獲取,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-05-05
  • Ubuntu 20.04 上安裝和使用 Docker的詳細(xì)過程(安裝包)

    Ubuntu 20.04 上安裝和使用 Docker的詳細(xì)過程(安裝包)

    這篇文章主要介紹了Ubuntu 20.04 上安裝和使用 Docker的詳細(xì)過程(安裝包),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-03-03
  • Docker?隔離與限制原理介紹

    Docker?隔離與限制原理介紹

    這篇文章主要介紹了Docker?隔離與限制原理,對(duì)于?Docker?等大多數(shù)?Linux?容器來說,Cgroups?技術(shù)是用來制造約束的主要手段,而?Namespace?技術(shù)則是用來修改進(jìn)程視圖的主要方法,下文相關(guān)介紹,需要的朋友可以參考一下
    2022-04-04
  • Docker容器自啟動(dòng)的實(shí)現(xiàn)方法

    Docker容器自啟動(dòng)的實(shí)現(xiàn)方法

    這篇文章主要介紹了Docker容器自啟動(dòng)的實(shí)現(xiàn)方法,詳細(xì)的介紹了Docker的 Restart policy命令,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2018-09-09
  • docker構(gòu)建鏡像需使用的命令小結(jié)

    docker構(gòu)建鏡像需使用的命令小結(jié)

    Docker 構(gòu)建鏡像的命令主要分為兩類:Dockerfile 指令與 docker build 命令,這篇文章主要介紹了docker構(gòu)建鏡像需使用的命令,需要的朋友可以參考下
    2007-01-01
  • docker容器存放目錄磁盤空間滿了的解決

    docker容器存放目錄磁盤空間滿了的解決

    這篇文章主要介紹了docker容器存放目錄磁盤空間滿了的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • docker如何修改容器ip范圍

    docker如何修改容器ip范圍

    這篇文章主要介紹了docker如何修改容器ip范圍問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03

最新評(píng)論