linux使用docker-compose部署软件配置详解
前言
本篇将分享一些 docker-compose 的配置,可参考其总结自己的一套基于docker的开发/生产环境配置。下面话不多说了,来一起看看详细的介绍吧
安装docker及docker-compose
install docker
curl -fssl https://get.docker.com | bash -s docker --mirror aliyun
install docker-compose
sudo curl -l https://github.com/docker/compose/releases/download/1.23.2/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose sudo chmod +x /usr/local/bin/docker-compose
创建专属网络
使用 docker network 创建自己的专属常用网络 me_gateway,使得 docker 的软件能够互相访问
docker network create me_gateway
docker-compose 部署 traefik
一个反向代理服务器,它非常快,有自动发现服务,自动申请 https 等非常棒的特性,,。
docker-compose.yml
这是一个使用 traefik 的 docker-compose.yml 配置示例
其中,挂载的 ./traefik.toml 为其配置,
挂载的 acme.json 为 let's encrypt 的配置
version: '3'
version: '3' services: me_traefik: image: traefik:1.7.4 container_name: me_traefik ports: - '80:80' - '443:443' - '8090:8090' volumes: - /var/run/docker.sock:/var/run/docker.sock - ./traefik.toml:/traefik.toml - ./acme.json:/acme.json networks: - webgateway networks: webgateway: external: name: me_gateway
traefik.toml
配置详细说明:http://docs.traefik.cn/toml#acme-lets-encrypt-configuration
以下为一个示例,在配置验证的时候遇到一些问题,可参考下面配置或者
################################################################ # global configuration ################################################################ # enable debug mode # # optional # default: false # debug = false # log level # # optional # default: "error" # loglevel = "error" # entrypoints to be used by frontends that do not specify any entrypoint. # each frontend can specify its own entrypoints. # # optional # default: ["http"] # defaultentrypoints = ["http","https"] ################################################################ # entrypoints configuration ################################################################ # entrypoints definition # # optional # default: # 要为一个入口点开启基础认证(basic auth) # 使用2组用户名/密码: test:test 与 test2:test2 # 密码可以以md5、sha1或bcrypt方式加密:你可以使用htpasswd来生成这些用户名密码。 # [entrypoints] # [entrypoints.http] # address = ":80" # [entrypoints.http.auth.basic] # users = ["test:$apr1$h6uskkkw$igxlp6ewtrsubktrqe8wj/", "test2:$apr1$d9hr9hbb$4hxwguir3hp4esggp/qno0"] # # 要为一个入口点开启摘要认证(digest auth) # 使用2组用户名/域/密码: test:traefik:test 与 test2:traefik:test2 # 你可以使用htdigest来生成这些用户名/域/密码 [entrypoints] [entrypoints.http] address = ":80" # [entrypoints.http.redirect] # entrypoint = "https" [entrypoints.https] address = ":443" [entrypoints.https.tls] [entrypoints.webentry] address = ":8090" [entrypoints.webentry.auth] [entrypoints.webentry.auth.basic] users = ["test:$apr1$h6uskkkw$igxlp6ewtrsubktrqe8wj/"] ################################################################ # api and dashboard configuration ################################################################ # enable api and dashboard [api] dashboard = true entrypoint = "webentry" ################################################################ # ping configuration ################################################################ # enable ping [ping] # name of the related entry point # # optional # default: "traefik" # # entrypoint = "traefik" ################################################################ # docker 后端配置 ################################################################ # 使用默认域名。 # 可以通过为容器设置"traefik.domain" label来覆盖。 # 启用docker后端配置 [docker] endpoint = "unix:///var/run/docker.sock" domain = "yimo.link" watch = true exposedbydefault = false usebindportip = true swarmmode = false network = "me_gateway" [acme] email = "yimo666666@qq.com" storage = "acme.json" entrypoint = "https" ondemand = false onhostrule = true [acme.httpchallenge] entrypoint="http"
docker-compose 部署 gogs,并使用 traefik 绑定域名
如果想要与 mysql 一起构建,可参考
docker-compose.yml
version: '3' services: me_gogs: restart: always image: gogs/gogs container_name: me_gogs volumes: - ./data:/data - ./logs:/app/gogs/log ports: - '10022:22' - '10080:3000' labels: - 'traefik.backend=me_gogs' - 'traefik.frontend.rule=host:git.yimo.link' - 'traefik.enable=true' - 'traefik.protocol=http' - 'traefik.port=3000' networks: - webgateway networks: webgateway: external: name: me_gateway
初始化时需要将域名设置为 0.0.0.0 或者git.yimo.link
即 ./data/gogs/conf/app.ini 项为
domain = git.yimo.link
docker-compose 部署 mysql
这个值得说明的就是,同一网络下,可直接使用 me_mysql 连接
docker-compose.yml
version: '3' services: me_mysql: image: mysql:5.7.21 container_name: me_mysql volumes: - ./data:/var/lib/mysql ports: - '3306:3306' environment: - mysql_root_password=root networks: - webgateway networks: webgateway: external: name: me_gateway
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
推荐阅读
-
Linux ifconfig命令详解和使用示例(Linux网络参数配置和查看)
-
linux使用docker-compose部署软件配置详解
-
linux系统rootkit恶意软件安全检测工具rkhunter安装部署、使用详解
-
Linux zabbix agent部署及配置方法详解
-
分布式系统监控软件——zabbix详解(四) 使用API的方式检索和修改zabbix的配置
-
linux上nginx安装部署及使用过程详解
-
VirtualBox软件下载安装及Linux环境安装部署图文教程详解
-
linux软件版本管理命令update-alternatives使用详解
-
LINUX 下软件包的安装与使用详解
-
Linux上搭载Nginx负载均衡配置使用案例详解