翼度科技»论坛 云主机 LINUX 查看内容

Docker常用软件安装

10

主题

10

帖子

30

积分

新手上路

Rank: 1

积分
30
jdk
  1. dockere pull openjdk:11
复制代码
  1. docker run -d -t --name java-11 openjdk:11
复制代码
MySQL
  1. 可以从docker hup中查找自己想要安装的版本
  2. docker pull mysql:5.7  拉取镜像
  3. 创建容器
  4. # 在/root目录下创建mysql目录用于存储mysql数据信息
  5. mkdir /root/mysql    cd /root/mysql
  6. docker run -id \
  7. -p 3307:3306 \
  8. --name=ydl_mysql \
  9. -v /root/mysql/conf:/etc/mysql/conf.d \
  10. -v /root/mysql/logs:/logs \
  11. -v /root/mysql/data:/var/lib/mysql \
  12. -e MYSQL_ROOT_PASSWORD=123456 \
  13. mysql:5.7
  14. 进入容器
  15. docker exec -it ydl_mysql /bin/bash
  16. 进入MySQL  
  17. mysql -uroot -p
  18. 123456
  19. 远程连接MySQL
  20. exit退出
  21. 如果远程连接有问题
  22. https://www.cnblogs.com/zhangxiaoxia/p/13043508.html
  23. 修改MySQL的字符编码
  24. 修改my.cnf 文件
  25. cd /mydata/mysql/conf
  26. vim my.conf
  27. [client]
  28. default-character-set=utf8mb4
  29. [mysql]
  30. default-character-set=utf8mb4
  31. [mysqld]
  32. init_connect='SET collation_connection = utf8mb4_bin'
  33. init_connect='SET NAMES utf8mb4'
  34. character_set_server = utf8mb4
  35. collation_server = utf8mb4_bin
  36. skip-character-set-client-handshake
  37. skip-name-resolve
复制代码

  • -p 3307:3306:将容器的 3306 端口映射到宿主机的 3307 端口。
  • -v $PWD/conf:/etc/mysql/conf.d:将主机当前目录下的 conf/my.cnf 挂载到容器的 /etc/mysql/my.cnf。配置目录
  • -v $PWD/logs:/logs:将主机当前目录下的 logs 目录挂载到容器的 /logs。日志目录
  • -v $PWD/data:/var/lib/mysql :将主机当前目录下的data目录挂载到容器的 /var/lib/mysql 。数据目录
  • -e MYSQL_ROOT_PASSWORD=123456:初始化 root 用户的密码。
MySQL5.7

谷粒商城
1 docker pull mysql:5.7  下载docker镜像
2 运行MySQL 容器
  1. docker run -p 3306:3306 --name mysql \
  2. -v /mydata/mysql/log:/var/log/mysql \
  3. -v /mydata/mysql/data:/var/lib/mysql \
  4. -v /mydata/mysql/conf:/etc/mysql \
  5. -e MYSQL_ROOT_PASSWORD=root \
  6. -d mysql:5.7
  7. 参数说明
  8. -p 3306:3306:将容器的 3306 端口映射到主机的 3306 端口
  9. -v /mydata/mysql/conf:/etc/mysql:将配置文件夹挂载到主机
  10. -v /mydata/mysql/log:/var/log/mysql:将日志文件夹挂载到主机
  11. -v /mydata/mysql/data:/var/lib/mysql/:将配置文件夹挂载到主机
  12. -e MYSQL_ROOT_PASSWORD=root:初始化 root 用户的密码为root
复制代码
3 SQLyong进行远程连接
  1. grant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;
  2. flush privileges 刷新权限
复制代码
4 修改配置文件
  1. cd /mydata/mysql/conf
  2. vim my.conf
  3. [client]
  4. default-character-set=utf8mb4
  5. [mysql]
  6. default-character-set=utf8mb4
  7. [mysqld]
  8. init_connect='SET collation_connection = utf8mb4_bin'
  9. init_connect='SET NAMES utf8mb4'
  10. character_set_server = utf8mb4
  11. collation_server = utf8mb4_bin
  12. skip-character-set-client-handshake
  13. skip-name-resolve
  14. 这个字符编码不要设置为utf8 MySQL容器会启动不起来 报错
  15. Error response from daemon: Container 7819b1b3c5a7f3efe4ec7e8bab59e80ad13f10a57b7b5484f664b205d3c1ce0d is not running
  16. 这个是错误示范
  17. [client]
  18. default-character-set=utf8
  19. [mysql]
  20. default-character-set=utf8
  21. [mysqld]
  22. init_connect='SET collation_connection = utf8_unicode_ci' init_connect='SET NAMES utf8' character-set-server=utf8
  23. collation-server=utf8_unicode_ci
  24. skip-character-set-client-handshake
  25. skip-name-resolve
  26. [mysqld]
  27. skip-name-resolve
复制代码
Tomcat

官方的webapps是没有文件是需要自己弄得
  1. docker search tomcat  
  2. docker pull tomcat
  3. 创建端口映射
  4. # 在/root目录下创建tomcat目录用于存储tomcat数据信息
  5. mkdir /root/tomcat
  6. cd /root/tomcat
  7. docker run -id --name=ydl_tomcat \
  8. -p 8081:8080 \
  9. -v /root/tomcat:/usr/local/tomcat/webapps \
  10. tomcat
  11. 外部访问
  12. http://宿主机ip:8081/
复制代码
Nginx
  1. docker search nginx
  2. docker pull nginx
  3. 端口映射
  4. # 在/root目录下创建nginx目录用于存储nginx数据信息
  5. mkdir /root/nginx
  6. cd /root/nginx
  7. mkdir conf
  8. cd conf
  9. 文件配置
  10. # 在~/nginx/conf/下创建nginx.conf文件,粘贴下面内容
  11. vim nginx.conf
  12. user  nginx;
  13. worker_processes  1;
  14. error_log  /var/log/nginx/error.log warn;
  15. pid        /var/run/nginx.pid;
  16. events {
  17.     worker_connections  1024;
  18. }
  19. http {
  20.     include       /etc/nginx/mime.types;
  21.     default_type  application/octet-stream;
  22.     log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
  23.                       '$status $body_bytes_sent "$http_referer" '
  24.                       '"$http_user_agent" "$http_x_forwarded_for"';
  25.     access_log  /var/log/nginx/access.log  main;
  26.     sendfile        on;
  27.     #tcp_nopush     on;
  28.     keepalive_timeout  65;
  29.     #gzip  on;
  30.     include /etc/nginx/conf.d/*.conf;
  31. }
  32. docker run -id --name=ydl_nginx \
  33. -p 80:80 \
  34. -v /root/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
  35. -v /root/nginx/logs:/var/log/nginx \
  36. -v /root/nginx/html:/usr/share/nginx/html \
  37. nginx
  38. 外部机器访问
复制代码
Redis
  1. docker search redis
  2. docker pull redis:5.0
  3. docker run -id --name=ydl_redis -p 6380:6379 redis:5.0
  4. 外部连接
复制代码
谷粒商城
  1. 1下载redis
  2. docker pull redis
  3. 如果不先创建这个conf文件 等会目录进行挂载的时候会吧redis.conf文件当成一个目录
  4. mkdir -p /mydata/redis/conf && touch /mydata/redis/conf/redis.conf
  5. 2 启动容器 目录挂载
  6. docker run -p 6379:6379 --name redis -v /mydata/redis/data:/data \
  7. -v /mydata/redis/conf/redis.conf:/etc/redis/redis.conf \
  8. -d redis redis-server /etc/redis/redis.conf
  9. 启动redis客户端
  10. 3  docker exec -it redis redis-cli
  11. 4  在redis.conf 中写入
  12. appendonly yes  开启AOF 持久化
复制代码
需要配置密码 如果不陪着密码很危险
  1. 1在创建容器的时候配置密码
  2. --requirepass
  3. 2 创建容器之后配置密码
  4. docker exec -it 容器ID bash
  5. 进入redis目录
  6. cd /usr/local/bin
  7. 运行命令:
  8. redis-cli
  9. 设置redis密码
  10. config set requirepass 密码
  11. 如出现:(error) NOAUTH Authentication required
  12. 这是因为redis设置了密码,我们需要使用密码来进行验证之后再来对redis客户端进行操作,否则我们没有操作redis缓存数据库的权限。
  13. 需要用  auth 密码
复制代码
如果使用redis  连接 Another Redis Desktop Manager
报错  Redis Client On Error: ReplyError: WRONGPASS invalid username-password pair or user is disabled. Con  就不要设置用户名
部署ELK

elasticsearch安装
1 下载镜像
  1. docker pull elasticsearch:7.4.2
复制代码
2  创建和容器内配置文件映射的文件
  1. mkdir -p /mydata/elasticsearch/config
  2. mkdir -p /mydata/elasticsearch/data
复制代码
3 添加配置文件
  1. echo "http.host: 0.0.0.0" >> /mydata/elasticsearch/config/elasticsearch.yml
复制代码
4 添加权限
  1. chmod -R 777 /mydata/elasticsearch/
复制代码
5 运行容器
  1. docker run --name elasticsearch -p 9200:9200 -p 9300:9300 \
  2. -e "discovery.type=single-node" \
  3. -e ES_JAVA_OPTS="-Xms256m -Xmx512m" \
  4. -v /mydata/elasticsearch/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml \
  5. -v /mydata/elasticsearch/data:/usr/share/elasticsearch/data \
  6. -v /mydata/elasticsearch/plugins:/usr/share/elasticsearch/plugins \
  7. -d elasticsearch:7.4.2
复制代码
kiban
  1. docker pull kibana:7.4.2
复制代码
  1. docker run --name kibana \
  2. -e ELASTICSEARCH_HOSTS=http://120.78.150.188:9200 -p 5601:5601 \
  3. -d kibana:7.4.2
复制代码
但是还要进行目录挂载修改 yml文件 设置中文
IK分词器
Ik分词器版本要和ES和Kibana版本保持一致 不然可能启动不了docker
进入容器
此命令需要在容器中运行

elasticsearch-plugin install https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v7.8.0/elasticsearch-analysis-ik-7.8.0.zip
退出容器,重启容器
  1. exit
  2. docker restart es7.8
复制代码
nacos

如果用docker安装naocs如果是 2版本可能会启动不了
  1. docker pull nacos/nacos-server:1.3.1
复制代码
  1. docker  run \
  2. --name nacos -d \
  3. -p 8848:8848 \
  4. --privileged=true \
  5. --restart=always \
  6. -e JVM_XMS=256m \
  7. -e JVM_XMX=256m \
  8. -e MODE=standalone \
  9. -e PREFER_HOST_MODE=hostname \
  10. nacos/nacos-server:1.3.1
复制代码
访问测试 http://43.138.137.168:8848/nacos

MQ
  1. docker run \
  2. -e RABBITMQ_DEFAULT_USER=zhuxiaoyi \
  3. -e RABBITMQ_DEFAULT_PASS=412826zxyZXY \
  4. --name rabbitmq \
  5. --hostname mq1 \
  6. -p 15672:15672 \
  7. -p 5672:5672 \
  8. -d \
  9. rabbitmq:3-management
复制代码
Nginx
  1. mkdir /root/docker/nginx
  2. mkdir /root/docker/nginx/conf
复制代码
由于我们现在没有配置文件,也不知道配置什么。可以先启动一个nginx,讲他的配置文件拷贝出来
再作为映射,启动真正的nginx
  1. docker pull nginx:1.17.4
  2. docker run --name some-nginx -d nginx:1.17.4
  3. docker container cp some-nginx:/etc/nginx /root/docker/nginx/conf
复制代码
然后就可以删除这个容器了
  1. docker docker rm -f some-nginx
复制代码
在重新启动nginx
  1. docker run --name nginx -p 80:80 \
  2.         -v /root/docker/nginx/conf:/etc/nginx \
  3.         -v /root/docker/nginx/html:/usr/share/nginx/html \
  4.         -d nginx:1.17.4
复制代码
FTP服务器

1 需要账号和密码
  1. docker run -v /data/dav:/usr/local/nginx/html  -d -p 88:80 lutixiaya/nwebdav:latest
  2. chmod o+w /data/dav
复制代码
ip+端口访问测试 需要输入账号和密码
使用winscp 进行连接
  1. 1、点击新建站点
  2. 2、选择协议
  3. 3、输入服务器ip
  4. 4、输入端口
  5. 5、输入用户名,默认用户:admin
  6. 6、输入密码,默认密码:bash.lutixia.cn
  7. 7、登录
复制代码
https://zhuanlan.zhihu.com/p/573721115   参考链接
2 无需账号和密码
在同一个文件目录下准备好这个三个文件
  1. start-nginx.sh
复制代码
  1. #!/bin/bash
  2. mkdir data
  3. docker stop nginx_file_server
  4. docker rm nginx_file_server
  5. docker run -d -p 8081:8080\
  6.         --name nginx_file_server \
  7.         -v $(pwd)/data:/data \
  8.         -v $(pwd)/nginx.conf:/etc/nginx/nginx.conf \
  9.         -v $(pwd)/default.conf:/etc/nginx/conf.d/default.conf \
  10.         nginx:stable-alpine
  11. nginx.conf
复制代码
nginx.conf
  1. user  root;
  2. worker_processes  1;
  3. error_log  /var/log/nginx/error.log warn;
  4. pid        /var/run/nginx.pid;
  5. events {
  6.     worker_connections  1024;
  7. }
  8. http {
  9.     include       /etc/nginx/mime.types;
  10.     default_type  application/octet-stream;
  11.     log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
  12.                       '$status $body_bytes_sent "$http_referer" '
  13.                       '"$http_user_agent" "$http_x_forwarded_for"';
  14.     access_log  /var/log/nginx/access.log  main;
  15.     sendfile        on;
  16.     #tcp_nopush     on;
  17.     keepalive_timeout  65;
  18.     #gzip  on;
  19.     include /etc/nginx/conf.d/*.conf;
  20. }
  21. default.conf
复制代码
default.conf
  1. server {
  2.     listen 8080; #端口
  3.     server_name localhost; #服务名
  4.     # for SSL listen port only
  5.     #ssl_certificate                /etc/nginx/conf.d/server.pem;
  6.     #ssl_certificate_key            /etc/nginx/conf.d/server-key.pem;
  7.     #ssl_protocols                  TLSv1.2;
  8.     #ssl_prefer_server_ciphers      on;
  9.     #ssl_session_timeout            5m;
  10.     #ssl_ciphers                    ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
  11.     #underscores_in_headers         on;
  12.     charset utf-8; # 避免中文乱码
  13.     root /data; #显示的根索引目录,注意这里要改成你自己的,目录要存在
  14.     location / {
  15.         autoindex on;             #开启索引功能
  16.         autoindex_exact_size off; # 关闭计算文件确切大小(单位bytes),只显示大概大小(单位kb、mb、gb)
  17.         autoindex_localtime on;   # 显示本机时间而非 GMT 时间
  18.     }
  19. }
复制代码
chmod +x start-nginx.sh && ./start-nginx.sh`
测试一下:
  1. echo file_server > data/file1.txt
复制代码
打开浏览器 http://127.0.0.1:8081/

DockerCompose
  1. sudo curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
复制代码
  1. sudo chmod +x /usr/local/bin/docker-compose
复制代码
  1. docker-compose --version
复制代码
安装GitLab

1 下载镜像
  1. docker pull twang2218/gitlab-ce-zh
复制代码
2 启动容器
  1. docker run -d -p 8443:443 -p 8090:80 -p 8022:22 --restart always --name gitlab -v /usr/local/gitlab/etc:/etc/gitlab -v /usr/local/gitlab/log:/var/log/gitlab -v /usr/local/gitlab/data:/var/opt/gitlab --privileged=true twang2218/gitlab-ce-zh
复制代码
3 进入容器修改配置文件
由于进行了目录映射 也可以不在容器内部进行修改
  1. docker exec -it gitlab bash
  2. cd /etc/gitlab
  3. vim /etc/gitlab/gitlab.yml
复制代码
4 修改配置文件
搜索URL
external_url 'http://gitlab.example.com'
把url换成自己的
external_url 'http://116.205.133.97/'
nginx['listen_port'] = nil
nginx['listen_port'] = 82    这个是注释掉的
5 重启服务
这是在容器内部重启服务
  1. gitlab-ctl restart
复制代码
gitlab是有很多组件组成的只有这些组件都运行成功了,才启动成功。

6 访问测试
http://120.78.214.226:8090
第一次登录默认是root用户 密码自己设定  不要低于8位

安装Jenkins

1 下载镜像
  1. docker pull jenkinsci/blueocean    中文版本
复制代码
2 创建目录
  1. # mkdir /home/jenkins_home
  2. # chown -R 1000:1000 /home/jenkins_home/
  3. # chown -R 1000:1000 /usr/local/src/jdk/jdk1.8/
  4. # chown -R 1000:1000 /opt/apache-maven-3.5.0/
复制代码
3 运行容器
  1. docker run \
  2. -d \
  3. --name jenkins \
  4. -p 9999:8080 \
  5. -p 8888:8888 \
  6. -p 50000:50000 \
  7. -v /usr/local/src/jdk/jdk1.8:/usr/local/src/jdk/jdk1.8 \
  8. -v /opt/apache-maven-3.5.0:/opt/apache-maven-3.5.0 \
  9. -v/home/jenkins_home:/var/jenkins_home \
  10. jenkins/jenkins:2.222.3-centos
复制代码
4 查看密码
  1. docker exec -it jenkins bash
  2. cat /var/jenkins_home/secrets/initialAdminPassword
复制代码
b0468f2eb870422abf509fe59f74e003
5 访问测试
http://120.78.214.226:9999/
6 进行汉化
在安装插件页面输入 chinese
7 替换插件下载地址
  1. https://blog.csdn.net/weixin_45878889/article/details/123867587
复制代码
安装SonarQube

https://blog.csdn.net/OfficerGoodbody/article/details/126662724
新版SonarQube不支持MySQL
1 下载postgres镜像
docker pull postgres
2 创建文件
  1. mkdir -p /opt/postgres/postgresql
  2. mkdir -p /opt/postgres/data
复制代码
3 创建网络
docker network create sonarqube
4 运行postgres 容器
  1. docker run --name postgres -d -p 5432:5432 --net sonarqube \
  2. -v /opt/postgres/postgresql:/var/lib/postgresql \
  3. -v /opt/postgres/data:/var/lib/postgresql/data \
  4. -v /etc/localtime:/etc/localtime:ro \
  5. -e POSTGRES_USER=sonar \
  6. -e POSTGRES_PASSWORD=sonar \
  7. -e POSTGRES_DB=sonar \
  8. -e TZ=Asia/Shanghai \
  9. --restart always \
  10. --privileged=true \
  11. --network-alias postgres \
  12. postgres:latest
复制代码
5 安装 sonarQube
  1. docker pull sonarqube
复制代码
6 准备文件夹
mkdir -p /opt/sonarqube
  1. echo "vm.max_map_count=262144" > /etc/sysctl.conf
  2. sysctl -p
复制代码
7 先运行一下拷贝文件
  1. docker run -d --name sonarqube sonarqube
复制代码
  1. docker cp sonarqube:/opt/sonarqube/conf /opt/sonarqube
  2. docker cp sonarqube:/opt/sonarqube/data /opt/sonarqube
  3. docker cp sonarqube:/opt/sonarqube/logs /opt/sonarqube
  4. docker cp sonarqube:/opt/sonarqube/extensions /opt/sonarqube
复制代码
8 删除容器
  1. docker stop  sonarqube
  2. docker rm  sonarqube
复制代码
9 添加权限
  1. chmod -R 777 /opt/sonarqube/
复制代码
10 修改配置文件
  1. vim /opt/sonarqube/conf/ sonar.properties
  2. 修改账号和密码
  3. sonar.jdbc.username=sonar
  4. sonar.jdbc.password=sonar
  5. sonar.jdbc.url=jdbc:postgresql://postgres:5432/sonar
复制代码
11 运行容器
  1. docker run -d --name sonarqube -p 9090:9000 \
  2. -e ALLOW_EMPTY_PASSWORD=yes \
  3. -e SONARQUBE_DATABASE_USER=sonar \
  4. -e SONARQUBE_DATABASE_NAME=sonar \
  5. -e SONARQUBE_DATABASE_PASSWORD=sonar \
  6. -e SONARQUBE_JDBC_URL="jdbc:postgresql://postgres:5432/sonar" \
  7. --net sonarqube \
  8. --privileged=true \
  9. --restart always \
  10. -v /opt/sonarqube/logs:/opt/sonarqube/logs \
  11. -v /opt/sonarqube/conf:/opt/sonarqube/conf \
  12. -v /opt/sonarqube/data:/opt/sonarqube/data \
  13. -v /opt/sonarqube/extensions:/opt/sonarqube/extensions\
  14. sonarqube
复制代码
12测试访问
浏览器输入http://ip:9090,开始初始化数据库初始化成功后进入登录界面,账号:admin  密码:admin
轻量级容器监控

portanier
下载   docker pull lihaixin/portainer
  1. docker run -d -p 9000:9000 --restart=always \
  2. -v /var/run/docker.sock:/var/run/docker.sock \
  3. --name portainer lihaixin/portainer
复制代码
访问测试   http://43.138.137.168:9000/#/home
<img alt="" loading="lazy">

重量级 容器监控

docker-compose.yml配置
  1. version: '3.1'
  2. volumes:
  3.   grafana_data: {}
  4. services:
  5. influxdb:
  6.   image: tutum/influxdb:0.9
  7.   restart: always
  8.   environment:
  9.     - PRE_CREATE_DB=cadvisor
  10.   ports:
  11.     - "8083:8083"
  12.     - "8086:8086"
  13.   volumes:
  14.     - ./data/influxdb:/data
  15. cadvisor:
  16.   image: google/cadvisor
  17.   links:
  18.     - influxdb:influxsrv
  19.   command:
  20.    -storage_driver=influxdb - storage_driver_db=cadvisor -storage_driver_host=influxsrv:8086
  21.   restart: always
  22.   ports:
  23.     - "8080:8080"
  24.   volumes:
  25.     - /:/rootfs:ro
  26.     - /var/run:/var/run:rw
  27.     - /sys:/sys:ro
  28.     - /var/lib/docker/:/var/lib/docker:ro
  29. grafana:
  30.   user: "104"
  31.   image: grafana/grafana
  32.   user: "104"
  33.   restart: always
  34.   links:
  35.     - influxdb:influxsrv
  36.   ports:
  37.     - "3000:3000"
  38.   volumes:
  39.     - grafana_data:/var/lib/grafana
  40.   environment:
  41.     - HTTP_USER=admin
  42.     - HTTP_PASS=admin
  43.     - INFLUXDB_HOST=influxsrv
  44.     - INFLUXDB_PORT=8086
  45.     - INFLUXDB_NAME=cadvisor
  46.     - INFLUXDB_USER=root
  47.     - INFLUXDB_PASS=root
复制代码
docker-compose up -d

来源:https://www.cnblogs.com/zhuxiaoyi412826/p/17261792.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具