Docker安装_应用部署_Redis(含密码)_ES(7.x含密码)_DockerCompose_Docker 私有仓库
程序员文章站
2022-07-14 12:14:43
...
一. 安装Docker
# 1、yum 包更新到最新
yum update
# 2、安装需要的软件包, yum-util 提供yum-config-manager功能,另外两个是devicemapper驱动依赖的
yum install -y yum-utils device-mapper-persistent-data lvm2
# 3、 设置yum源
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
# 4、 安装docker,出现输入的界面都按 y
yum install -y docker-ce
# 5、 查看docker版本,验证是否验证成功
docker -v
二. Docker 应用部署
1. 部署MySQL
1.1 创建容器,设置端口映射、目录映射
# 在/root目录下创建mysql目录用于存储mysql数据信息
mkdir ~/mysql
cd ~/mysql
docker run -id \
-p 3306:3306 \
--name=c_mysql \
-v $PWD/conf:/etc/mysql \
-v $PWD/logs:/logs \
-v $PWD/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=password\
mysql:5.7
1.4 进入容器,操作mysql
docker exec –it c_mysql /bin/bash
2. 部署Tomcat
2.1 创建容器,设置端口映射、目录映射
# 在/root目录下创建tomcat目录用于存储tomcat数据信息
mkdir ~/tomcat
cd ~/tomcat
docker run -id --name=c_tomcat \
-p 8080:8080 \
-v $PWD:/usr/local/tomcat/webapps \
tomcat
3. 部署Nginx
3.1 创建容器,设置端口映射、目录映射
- 配置
# 在/root目录下创建nginx目录用于存储nginx数据信息
mkdir ~/nginx
cd ~/nginx
mkdir conf
cd conf
# 在~/nginx/conf/下创建nginx.conf文件,粘贴下面内容
vim nginx.conf
user nginx;
worker_processes 1;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
#tcp_nopush on;
keepalive_timeout 65;
#gzip on;
include /etc/nginx/conf.d/*.conf;
}
- 启动
docker run -id --name=c_nginx \
-p 80:80 \
-v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf \
-v $PWD/logs:/var/log/nginx \
-v $PWD/html:/usr/share/nginx/html \
nginx
4. 部署Redis
4.1 创建容器,设置端口映射
docker run -id --name=c_redis -p 6379:6379 redis:5.0 --requirepass "password"
5. 部署ES
5.1 创建容器,设置端口映射
- 配置
- 创建elasticsearch.yml文件
cluster.name: "docker-cluster"
network.host: 0.0.0.0
http.cors.enabled: true
http.cors.allow-origin: "*"
- 运行
docker run --restart=always -p 9200:9200 -p 9300:9300 -v $PWD/plugins:/usr/share/elasticsearch/plugins -v $PWD/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml -e "discovery.type=single-node" -e ES_JAVA_OPTS="-Xms512m -Xmx512m" --name='c_elasticsearch' --cpuset-cpus="1" -m 2G -d elasticsearch:7.7.0
-e 分配内存 默认是1g内存,虚拟机1G的小的建议给150M就好。
//进入容器安装ik分词器
docker exec -it es容器id /bin/bash
cd /usr/share/elasticsearch/plugins/
elasticsearch-plugin install https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v7.7.0/elasticsearch-analysis-ik-7.7.0.zip
//ik 需要和es版本一致。
//解决es跨域请求。
cd /usr/share/elasticsearch/config/
vi elasticsearch.yml
添加以下内容
http.cors.enabled: true
http.cors.allow-origin: "*"
//退出容器
exit
//重启生效
docker restart
- 设置密码
- 修改elasticsearch.yml文件
xpack.security.enabled: true
- 进入es容器
cd bin
elasticsearch-setup-passwords interactive #设置密码
[apm_system]
[kibana]
[logstash_system]
[beats_system]
[remote_monitoring_user]
[elastic]
6. 部署kibana
6.1 创建容器,设置映射
- 配置
cd ~/kibana
mkdir conf
vim config/kibana.yml
server.name: kibana
server.host: "0.0.0.0" #远程连接
elasticsearch.hosts: [ "http://xxxxx:9200" ] #连接es
xpack.monitoring.ui.container.elasticsearch.enabled: true
i18n.locale: "zh-CN" #汉化
- 启动
cd ~/kibana
docker run -d --restart=always --log-driver json-file --log-opt max-size=100m --log-opt max-file=2 --name c_kibana -p 5601:5601 -v $PWD/config/kibana.yml:/usr/share/kibana/config/kibana.yml kibana:7.7.0
- 启动后进行配置的话
docker exec -it kibana bash
vi config/kibana.yml
docker restart kibana
- es设置密码之后需要修改配置
elasticsearch.username: "elastic"
elasticsearch.password: "xxxxxx"
xpack.monitoring.ui.container.elasticsearch.enabled: true
7. 部署Logstash
7.1 创建容器,设置映射
- 配置文件目录
mkdir -p /usr/local/logstash/config
cd /usr/local/logstash/config
touch logstash.yml
vi log4j2.properties
#####添加以下内容
logger.elasticsearchoutput.name = logstash.outputs.elasticsearch
logger.elasticsearchoutput.level = debug
#####
vi pipelines.yml
####
- pipeline.id: logstash-match
path.config: "/usr/share/logstash/config/*.conf"
pipeline.workers: 3
####
- 启动
docker run -d -p 5044:5044 -p 9600:9600 -it \
--name logstash \
-v /usr/local/logstash/config/:/usr/share/logstash/config/ \
logstash:7.5.0
8. 部署rabbitmq
docker run -d --name c_rabbitmq -e RABBITMQ_DEFAULT_USER=root -e RABBITMQ_DEFAULT_PASS=password-p 15672:15672 -p 5672:5672 rabbitmq:3-management
三. Docker Compose
1. 安装Docker Compose
# Compose目前已经完全支持Linux、Mac OS和Windows,在我们安装Compose之前,需要先安装Docker。下面我 们以编译好的二进制包方式安装在Linux系统中。
curl -L https://github.com/docker/compose/releases/download/1.22.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
# 设置文件可执行权限
chmod +x /usr/local/bin/docker-compose
# 查看版本信息
docker-compose -version
2. 卸载Docker Compose
# 二进制包方式安装的,删除二进制文件即可
rm /usr/local/bin/docker-compose
四. Docker 私有仓库
## Docker 私有仓库
1. 私有仓库搭建
# 1、拉取私有仓库镜像
docker pull registry
# 2、启动私有仓库容器
docker run -id --name=registry -p 5000:5000 registry
# 3、打开浏览器 输入地址http://私有仓库服务器ip:5000/v2/_catalog,看到{"repositories":[]} 表示私有仓库 搭建成功
# 4、修改daemon.json
vim /etc/docker/daemon.json
# 在上述文件中添加一个key,保存退出。此步用于让 docker 信任私有仓库地址;注意将私有仓库服务器ip修改为自己私有仓库服务器真实ip
{"insecure-registries":["私有仓库服务器ip:5000"]}
# 5、重启docker 服务
systemctl restart docker
docker start registry
2. 将镜像上传至私有仓库
# 1、标记镜像为私有仓库的镜像
docker tag centos:7 私有仓库服务器IP:5000/centos:7
# 2、上传标记的镜像
docker push 私有仓库服务器IP:5000/centos:7
3. 从私有仓库拉取镜像
#拉取镜像
docker pull 私有仓库服务器ip:5000/centos:7