Docker安装_应用部署_Redis(含密码)_ES(7.x含密码)_DockerCompose_Docker 私有仓库

一. 安装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 创建容器,设置端口映射、目录映射

  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;
}
  1. 启动
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 创建容器,设置端口映射

  1. 配置
  • 创建elasticsearch.yml文件
cluster.name: "docker-cluster"
network.host: 0.0.0.0
http.cors.enabled: true
http.cors.allow-origin: "*"
  1. 运行
 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
  1. 设置密码
  • 修改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 创建容器,设置映射

  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"  #汉化
  1. 启动
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  
  1. 启动后进行配置的话
docker exec  -it kibana bash
vi config/kibana.yml
docker restart kibana
  1. es设置密码之后需要修改配置
elasticsearch.username: "elastic"
elasticsearch.password: "xxxxxx"
xpack.monitoring.ui.container.elasticsearch.enabled: true

7. 部署Logstash

7.1 创建容器,设置映射

  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
####
  1. 启动
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

你可能感兴趣的:(安装部署,docker,elasticsearch,redis,linux)