首页 > 其他分享 >docker & docker-compose使用汇总

docker & docker-compose使用汇总

时间:2024-02-29 21:46:17浏览次数:25  
标签:compose -- redis 汇总 nginx proxy docker net

安装docker/docker-compose

 1.直接在docker网站上下载dmg安装包安装

 2.命令行安装  sudo pip install -U docker-compose

 

卸载docker/docker-compose

1.直接卸载安装包

2.命令行卸载

 

查看docker/docker-compose是否安装成功

docker --version

docker-compose  --version

 

新建网段

docker network create --subnet=172.18.0.0/16 mynet  #创建网段

docker network create --driver bridge --subnet=172.18.0.0/16 mynet # 以桥接(bridge)方式,创建名称为docker_net的网络

 

查询网段

docker network ls

 

删除网段

docker network rm mynet -->删除网段     给容器分配固定的IP地址

docker run --it --net mynet --ip 172.18.0.2 python:3.8 bash -->分配固定ip

--net   使用网段的名字

--ip   使用哪一个ip

注意:172.18.0.1是网段的网关地址,是不能用的

 

使用docker启动(以mysql为例)

# 运行mysql5.7,连到docker_net 这个自定义网络
docker run -d -p 13306:3306 -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 --net docker_net mysql:5.7

 

需要将已创建好的容器,连到某网路,也可以用 docker network connect 容器name 自定义网络name,如:

docker network connect mysql01 docker_net

 

-f:指定docker-compose.yml文件路径

-p:项目名称

-d:后台启动

 

portainer

docker-compose -f docker-compose-portainer.yml -p portainer up -d

version: '3'

services:

 portainer:

 image: registry.cn-hangzhou.aliyuncs.com/example/portainer:2.1.1

 container_name: portainer # 容器名为'portainer'

 restart: always # 指定容器退出后的重启策略为始终重启

 networks:

   docker_net:

     #服务在容器中ip(其他服务引用使用)

     ipv4_address: 172.22.16.2

 volumes: # 数据卷挂载路径设置,将本机目录映射到容器目录

   - ~/docker/portainer/data:/data

   - ~/docker/portainer/Portainer-CN:/public # 汉化

 environment: # 设置环境变量,相当于docker run命令中的-e

 TZ: Asia/Shanghai

 LANG: en_US.UTF-8

 ports: # 映射端口

 - "9001:9000"

networks:

 docker_net:

 external:

 name: docker_net

 

 

prometheus

version: "3"

services:

  prometheus:

    image: registry.cn-hangzhou.aliyuncs.com/example/prometheus:2.30.0

    container_name: prometheus

    networks:

      docker_net:

        ipv4_address: 172.22.16.120

    volumes:

      - ./prometheus/prometheus.yml:/etc/prometheus/prometheus.yml

    command: "--config.file=/etc/prometheus/prometheus.yml --storage.tsdb.path=/prometheus"

    ports:

      - "9090:9090"

    depends_on:

      - exporter

  exporter:

    image: registry.cn-hangzhou.aliyuncs.com/example/node-exporter:1.2.2

    container_name: prometheus_exporter

    ports:

      - "9100:9100"

    networks:

      docker_net:

        ipv4_address: 172.22.16.120

  # 用于UI展示

  # https://grafana.com/docs/grafana/latest/installation/docker

  grafana:

    image: registry.cn-hangzhou.aliyuncs.com/example/grafana:8.1.5

    container_name: prometheus_grafana

    restart: unless-stopped

    ports:

      - "3000:3000"

#    volumes:

#      - "./prometheus/grafana/grafana-storage:/var/lib/grafana"

#      - "./prometheus/grafana/public:/usr/share/grafana/public" # 这里面可处理汉化包 可参考 https://github.com/WangHL0927/grafana-chinese

#      - "./prometheus/grafana/conf:/usr/share/grafana/conf"

#      - "./prometheus/grafana/log:/var/log/grafana"

#      - "/etc/localtime:/etc/localtime"

    environment:

      GF_EXPLORE_ENABLED: "true"

      GF_SECURITY_ADMIN_PASSWORD: "admin"

      GF_INSTALL_PLUGINS: "grafana-clock-panel,grafana-simple-json-datasource,alexanderzobnin-zabbix-app"

      # 持久化到mysql数据库

      GF_DATABASE_URL: "mysql://root:123456:3306/grafana" # TODO 修改

    depends_on:

      - prometheus

    networks:

      docker_net:

        ipv4_address: 172.22.16.120

networks:

  docker_net:

    external:

      name: docker_net

 

 

mysql8

docker-compose -f docker-compose-mysql8.0.yml -p mysql8 up -d

version: '3'

services:

  mysql:

    image: registry.cn-hangzhou.aliyuncs.com/example/mysql8:8.0.27

    container_name: mysql8  # 容器名为'mysql8'

    command:

    # MySQL8的密码验证方式默认是 caching_sha2_password,但是很多的连接工具还不支持该方式

    # 就需要手动设置下mysql的密码认证方式为以前的 mysql_native_password 方式

      --default-authentication-plugin=mysql_native_password

      --character-set-server=utf8mb4

      --collation-server=utf8mb4_general_ci

    restart: unless-stopped

    networks:

      docker_net:

        #服务在容器中ip(其他服务引用使用)

        ipv4_address: 172.22.16.80

    volumes:

      - ~/docker/mysql8/data:/var/lib/mysql

      - ~/docker/mysql8/conf:/etc/mysql/conf.d

      - ~/docker/mysql8/logs:/logs                                            

    environment:                        # 设置环境变量,相当于docker run命令中的-e

      TZ: Asia/Shanghai

      LANG: en_US.UTF-8

      MYSQL_ROOT_PASSWORD: 123456       # 设置root用户密码

    ports:                              # 映射端口

      - "3306:3306"

networks:

  docker_net:

    external:

      name: docker_net

 

创建用户(创建root用户,可通过密码123456从任何主机登录)

 create user 'root'@'%' identified by  '123456';

授予用户权限(授予该用户所有权限)

 GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;  

3.刷新权限 

flush privileges;

完成上述操作后,出现如下错误 authentication plugin ‘caching_sha2_password’ cannot be loaded

是mysql账户密码加密规则问题,修改账户加密规则

 

#修改加密规则
ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER;
#更新一下用户的密码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password';

 

 

nacos

version: '3'

services:

  nacos:

    image: registry.cn-hangzhou.aliyuncs.com/example/nacos:2.0.3

    container_name: nacos  # 容器名为'nacos'

    restart: unless-stopped  # 指定容器退出后的重启策略为始终重启,但是不考虑在Docker守护进程启动时就已经停止了的容器

    networks:

      docker_net:

        #服务在容器中ip(其他服务引用使用)

        ipv4_address: 172.22.16.100

    volumes:  # 数据卷挂载路径设置,将本机目录映射到容器目录

      - ~/docker/nacos/logs:/home/nacos/logs

      # mysql8版本以上才需要额外此配置信息

      - ~/docker/nacos_mysql_2.0.3/plugins/mysql:/home/nacos/plugins/mysql

    environment:  # 设置环境变量,相当于docker run命令中的-e

      - "PREFER_HOST_MODE=ip"

      - "MODE=standalone"

      - "MYSQL_DATABASE_NUM=1"

      - "SPRING_DATASOURCE_PLATFORM=mysql"

      #容器中mysql服务的ip

      - "MYSQL_SERVICE_HOST= 172.22.16.80"

      - "MYSQL_SERVICE_DB_NAME=nacos"

      - "MYSQL_SERVICE_PORT=3306"

      - "MYSQL_SERVICE_USER=root"

      - "MYSQL_SERVICE_PASSWORD=123456"

    ports:  # 映射端口  (Nacos2.0版本相比1.X新增了gRPC的通信方式,因此需要增加2个端口:9848、9849)

      - "8848:8848"

      - "9848:9848"

      - "9849:9849"

      - "9555:9555"

    mem_limit: 1000m   # 最大使用内存

networks:

  docker_net:

    external:

      name: docker_net

 

 

nginx

version: '3'

services:

  nginx:

    image: registry.cn-hangzhou.aliyuncs.com/example/nginx:1.21.1  # 镜像`nginx:1.21.1`

    container_name: nginx  # 容器名为'nginx'

    networks:

      docker_net:

        #服务在容器中ip(其他服务引用使用)

        ipv4_address: 172.22.16.105

    restart: unless-stopped  # 指定容器退出后的重启策略为始终重启,但是不考虑在Docker守护进程启动时就已经停止了的容器

    volumes:  # 数据卷挂载路径设置,将本机目录映射到容器目录

      - "/home/dubbo/nginx/conf/nginx.conf:/etc/nginx/nginx.conf"

      - "/home/dubbo/nginx/conf/conf.d/:/etc/nginx/conf.d/"

      - "/home/dubbo/nginx/html:/home/dubbo/nginx/html"

      - "/home/dubbo/nginx/log:/var/log/nginx"

    environment:  # 设置环境变量,相当于docker run命令中的-e

      TZ: Asia/Shanghai

      LANG: en_US.UTF-8

    ports:  # 映射端口

      - "80:80"

networks:

  docker_net:

    external:

      name: docker_net

 

配置文件信息: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;

}

 

 

配置文件信息:conf.d/default.conf

 

server {
listen 80;
server_name localhost;
client_max_body_size 100M;
#前端项目1
location /web/ {
root /home/dubbo/nginx/html;
index index.html index.htm;
try_files $uri $uri/ /index.html; #解决刷新404
}
location /api/ {
add_header Access-Control-Allow-Origin *;
add_header Access-Control-Allow-Methods *;
proxy_buffering off;
proxy_redirect off;
proxy_set_header Host $host:$server_port;
proxy_set_header proxy_url "api";
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_connect_timeout 60;
proxy_send_timeout 120;
proxy_read_timeout 120;
proxy_pass http://1.15.240.63:6443/api/;
}
location /nacos/ {
add_header Access-Control-Allow-Origin *;
add_header Access-Control-Allow-Methods *;
proxy_buffering off;
proxy_redirect off;
proxy_set_header Host $host:$server_port;
proxy_set_header proxy_url "api";
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_connect_timeout 60;
proxy_send_timeout 120;
proxy_read_timeout 120;
proxy_pass http://nacos:8848/nacos/;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}

 

前端配置例子:

volumes:  # 数据卷挂载路径设置,将本机目录映射到容器目录

  - "/home/dubbo/nginx/html:/home/dubbo/nginx/html"

  注意:

  前端项目放在宿主机/home/dubbo/nginx/html下的html目录下,

  nginx启动时会加载更新到docker容器中的/home/dubbo/nginx/html中,可以放多个项目。

#nginx中前端项目1示例

location /web/ {

        root /home/dubbo/nginx/html;

        index index.html index.htm;

        try_files $uri $uri/ /index.html; #解决刷新404

}

 

前端打包:vue.config.js中module.exports = { 下

publicPath: '/web/',

outputDir: 'web',

assetsDir: 'static',

productionSourceMap: false,

 

前端打包:vue.config.js中publicPath配置 './'时使用第1种:

nginx使用 第1种: assetsPublicPath: './'

location / {

    root /home/dubbo/nginx/html;

    index index.html index.htm;

}

前端打包:vue.config.js中publicPath配置 '/web/'时使用第2种或者第3种:

nginx使用 第2种: assetsPublicPath: '/web/'

location /web/ {

     root /home/dubbo/nginx/html;

     index index.html index.htm;

     try_files $uri $uri/ /index.html; #解决刷新404

}

第3种:

location /web/ {

     alias /home/dubbo/nginx/html/web;

     index index.html index.php index.htm;

}

 

 

redis

 

version: '3'

services:

  redis:

    image: registry.cn-hangzhou.aliyuncs.com/example/redis:6.0.8  # 镜像'redis:6.0.8'

    container_name: redis  # 容器名为'redis'

    networks:

      docker_net:

        #服务在容器中ip(其他服务引用使用)

        ipv4_address: 172.22.16.79

    restart: unless-stopped  # 指定容器退出后的重启策略为始终重启,但是不考虑在Docker守护进程启动时就已经停止了的容器

    command: redis-server /etc/redis/redis.conf --requirepass 123456 --appendonly no # 启动redis服务并添加密码为:123456,默认不开启redis-aof方式持久化配置

#    command: redis-server --requirepass 123456 --appendonly yes # 启动redis服务并添加密码为:123456,并开启redis持久化配置

    environment:                        # 设置环境变量,相当于docker run命令中的-e

      TZ: Asia/Shanghai

      LANG: en_US.UTF-8

    volumes:                            # 数据卷挂载路径设置,将本机目录映射到容器目录

      - "./redis/data:/data"

      - "./redis/config/redis.conf:/etc/redis/redis.conf"  # `redis.conf`文件内容`http://download.redis.io/redis-stable/redis.conf`

    ports:                              # 映射端口

      - "6379:6379"

networks:

  docker_net:

    external:

      name: docker_net

 

 

使用docker-compose部署服务项目

docker-compose -f docker-compose-gateway.yml -p oms-gateway up -d

 

version: "3"

services:

  oms-gateway:

    # 指定容器名称

    container_name: oms-gateway

    networks:

      docker_net:

        #服务在容器中ip(其他服务引用使用)

        ipv4_address: 172.22.16.150

    # 重启机制

    restart: always

    image: java:8

    volumes:

      # 本地jar包路径

      - /home/dubbo/gateway/oms-gateway-1.0.0.jar:/oms-gateway-1.0.0.jar

      # 挂载日志 -v A:B ,A指宿主机位置,B指容器位置

      - /usr/logs:/logs

      # 指定容器时间为宿主机时间

      - /etc/localtime:/etc/localtime

    # 访问端口

    ports:

      - "6443:6443"

    environment:

      TZ: Asia/Shanghai

      LANG: en_US.UTF-8

    #启动容器后执行的命令

    entrypoint: java -server -Xms256m -Xmx256m -jar -Dfile.encoding=utf-8 -Dspring.profiles.active=dev oms-gateway-1.0.0.jar

networks:

  docker_net:

    external:

      name: docker_net

 

 

 

 

 

 

标签:compose,--,redis,汇总,nginx,proxy,docker,net
From: https://www.cnblogs.com/yating/p/18045560

相关文章

  • ICMP类型字段(Type)以及代码字段(Code)含义汇总
    ICMP报文可分为两大类:一、有关信息采集和配置的ICMP报文(称为查询(query)或者信息类报文(informationmessage)),二、有关IP数据报传递的ICMP报文(称为差错报文(errormessage)).typecodeDescriptionqueryerror00EchoReply——回显应答(Ping应答)x30NetworkUnreac......
  • linux 使用docker 管理应用(gitlab,)
    配置gitlab  10080端口貌似被禁用的具体细节不清楚但是配置访问不了端口从2万开始磁盘空间不足无法正常启动 需要配置足够的磁盘空间配置环境变量 GITLAB_HOME下载并启动容器sudodockerrun--detach--hostnamegitlab.example.com--publish10443:443--publ......
  • docker-compose安装Gitlab Runner
    系列文章GitlabRunner的docker-compose.ymlversion:'3'services:home:image:'gitlab/gitlab-runner:v16.9.0'scale:2restart:alwaysprivileged:truevolumes:-./config:/etc/gitlab-runner准备好文件之后,放在某个文件夹下root......
  • docker 部署.net core 3.1程序
    docker安装安装所需的软件包,yum-utils提供了yum-config-manager,并且devicemapper存储驱动程序需要device-mapper-persistent-data和lvm2。sudoyuminstall-yyum-utils\device-mapper-persistent-data\lvm2使用命令来设置docker仓库(阿里源,官方源太慢了)sudo......
  • 常用css两列布局汇总
    浮动+margin<divclass="container"><divclass="left">定宽</div><divclass="right">自适应</div></div>/*不给高度不行,不给宽度可以自适应*/.container{height:300px;}.left{float:left;/*......
  • centos下部署docker
    一、docker概述docker是基于go语言实现的云开源项目,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布流行的linux和windows操作系统的机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口二、docker的优点系统平滑移植、容器虚拟化,从开发环......
  • .net 应用程序 生成Docker映像时 dotnet restore找不到自定义源的包的问题,ContainerBu
    一、问题:我们在.net应用中生成Docker映像时,会出现ContainerBuildAndLaunch任务意外失败的问题。 查看输出窗口发现,是执行dotnetrestore时,找不到包的问题,因为我的这些包是在自己的私有源上二、解决方案:在Dockerfile文件中,在执行dotnetrestore前一行添加nuget私有源就行......
  • 软考高项知识点汇总(一)
    一、信息与信息化1.信息(1)定义。1)控制论的创始人维纳认为:信息就是信息,它既不是物质也不是能量。2)根据信息化的奠基者香农的描述:信息用来“消除不确定的因素”。3)信息的概念存在两个基本的层次,即本体论层次和认识论层次。前者是纯客观的层次,只与客体本身的因素有关,与主体的因素......
  • 用Docker发布网站时,自动下载Directory.Build.props及其Import的文件
    为Blazor网站项目,“添加Docker支持”这时,网站项目根目录下会新增Dockerfile。#Seehttps://aka.ms/customizecontainertolearnhowtocustomizeyourdebugcontainerandhowVisualStudiousesthisDockerfiletobuildyourimagesforfasterdebugging.FROMmcr.......
  • centos docker服务问题
     概述docker的应用版本正式上线,结果一上线就出各种幺蛾子。本文档主要介绍centos系统安装docker和启动的问题解决方法。环境dockerregistry:2centos6&&docker1.7.1centos7&&docker24.0.6docker服务启动失败docker安装,命令会自动安装依赖libcgroup。yuminsta......