2023-03-27

Docker常用软件安装

jdk

dockere pull openjdk:11

docker run -d -t --name java-11 openjdk:11

MySQL

可以从docker hup中查找自己想要安装的版本

docker pull mysql:5.7  拉取镜像

创建容器

# 在/root目录下创建mysql目录用于存储mysql数据信息

mkdir/root/mysqlcd/root/mysql

docker run-id\

-p3307:3306 \

--name=ydl_mysql \

-v/root/mysql/conf:/etc/mysql/conf.d \

-v/root/mysql/logs:/logs \

-v/root/mysql/data:/var/lib/mysql \

-eMYSQL_ROOT_PASSWORD=123456\

mysql:5.7

进入容器

docker exec-itydl_mysql /bin/bash

进入MySQL  

mysql-uroot-p

123456

远程连接MySQL

exit退出

如果远程连接有问题

https://www.cnblogs.com/zhangxiaoxia/p/13043508.html

修改MySQL的字符编码

修改my.cnf 文件

cd/mydata/mysql/conf

vimmy.conf

[client]

default-character-set=utf8mb4

[mysql]

default-character-set=utf8mb4

[mysqld]

init_connect='SET collation_connection = utf8mb4_bin'

init_connect='SET NAMES utf8mb4'

character_set_server=utf8mb4

collation_server=utf8mb4_bin

skip-character-set-client-handshake

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 容器

docker run -p 3306:3306 --name mysql \

-v /mydata/mysql/log:/var/log/mysql \

-v /mydata/mysql/data:/var/lib/mysql \

-v /mydata/mysql/conf:/etc/mysql \

-e MYSQL_ROOT_PASSWORD=root \

-d mysql:5.7

参数说明

-p 3306:3306:将容器的 3306 端口映射到主机的 3306 端口

-v /mydata/mysql/conf:/etc/mysql:将配置文件夹挂载到主机

-v /mydata/mysql/log:/var/log/mysql:将日志文件夹挂载到主机

-v /mydata/mysql/data:/var/lib/mysql/:将配置文件夹挂载到主机

-e MYSQL_ROOT_PASSWORD=root:初始化 root 用户的密码为root

3 SQLyong进行远程连接

grant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;

flush privileges 刷新权限

4 修改配置文件

cd /mydata/mysql/conf

vim my.conf

[client]

default-character-set=utf8mb4

[mysql]

default-character-set=utf8mb4

[mysqld]

init_connect='SET collation_connection = utf8mb4_bin'

init_connect='SET NAMES utf8mb4'

character_set_server = utf8mb4

collation_server = utf8mb4_bin

skip-character-set-client-handshake

skip-name-resolve

这个字符编码不要设置为utf8 MySQL容器会启动不起来 报错

Error response from daemon: Container 7819b1b3c5a7f3efe4ec7e8bab59e80ad13f10a57b7b5484f664b205d3c1ce0d is not running

这个是错误示范

[client]

default-character-set=utf8

[mysql]

default-character-set=utf8

[mysqld]

init_connect='SET collation_connection = utf8_unicode_ci' init_connect='SET NAMES utf8' character-set-server=utf8

collation-server=utf8_unicode_ci

skip-character-set-client-handshake

skip-name-resolve

[mysqld]

skip-name-resolve

Tomcat

官方的webapps是没有文件是需要自己弄得

docker search tomcat  

docker pull tomcat

创建端口映射

# 在/root目录下创建tomcat目录用于存储tomcat数据信息

mkdir/root/tomcat

cd/root/tomcat

docker run-id--name=ydl_tomcat \

-p8081:8080 \

-v/root/tomcat:/usr/local/tomcat/webapps \

tomcat

外部访问

http://宿主机ip:8081/

Nginx

docker search nginx

docker pull nginx

端口映射

# 在/root目录下创建nginx目录用于存储nginx数据信息

mkdir/root/nginx

cd/root/nginx

mkdirconf

cdconf

文件配置

# 在~/nginx/conf/下创建nginx.conf文件,粘贴下面内容

vimnginx.conf

user  nginx;

worker_processes1;

error_log  /var/log/nginx/error.log warn;

pid        /var/run/nginx.pid;

events {

worker_connections1024;

}

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_timeout65;

#gzip  on;

   include /etc/nginx/conf.d/*.conf;

}

docker run-id--name=ydl_nginx \

-p80:80 \

-v/root/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \

-v/root/nginx/logs:/var/log/nginx \

-v/root/nginx/html:/usr/share/nginx/html \

nginx

外部机器访问

Redis

docker search redis

docker pull redis:5.0

docker run-id--name=ydl_redis-p6380:6379 redis:5.0

外部连接

谷粒商城

1下载redis

docker pull redis

如果不先创建这个conf文件 等会目录进行挂载的时候会吧redis.conf文件当成一个目录

mkdir -p /mydata/redis/conf && touch /mydata/redis/conf/redis.conf

2 启动容器 目录挂载

docker run -p 6379:6379 --name redis -v /mydata/redis/data:/data \

-v /mydata/redis/conf/redis.conf:/etc/redis/redis.conf \

-d redis redis-server /etc/redis/redis.conf

启动redis客户端

3  docker exec -it redis redis-cli

4  在redis.conf 中写入

appendonly yes  开启AOF 持久化

需要配置密码 如果不陪着密码很危险

1在创建容器的时候配置密码

--requirepass

2 创建容器之后配置密码

docker exec -it 容器ID bash

进入redis目录

cd /usr/local/bin

运行命令:

redis-cli

设置redis密码

config set requirepass 密码

如出现:(error) NOAUTH Authentication required

这是因为redis设置了密码,我们需要使用密码来进行验证之后再来对redis客户端进行操作,否则我们没有操作redis缓存数据库的权限。

需要用  auth 密码

如果使用redis  连接 Another Redis Desktop Manager

报错  Redis Client On Error: ReplyError: WRONGPASS invalid username-password pair or user is disabled. Con  就不要设置用户名

部署ELK

elasticsearch安装

1 下载镜像

docker pull elasticsearch:7.4.2

2  创建和容器内配置文件映射的文件

mkdir -p /mydata/elasticsearch/config

mkdir -p /mydata/elasticsearch/data

3 添加配置文件

echo "http.host: 0.0.0.0" >> /mydata/elasticsearch/config/elasticsearch.yml

4 添加权限

chmod -R 777 /mydata/elasticsearch/

5 运行容器

docker run --name elasticsearch -p 9200:9200 -p 9300:9300 \

-e "discovery.type=single-node" \

-e ES_JAVA_OPTS="-Xms256m -Xmx512m" \

-v /mydata/elasticsearch/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml \

-v /mydata/elasticsearch/data:/usr/share/elasticsearch/data \

-v /mydata/elasticsearch/plugins:/usr/share/elasticsearch/plugins \

-d elasticsearch:7.4.2

kiban

docker pull kibana:7.4.2

docker run --name kibana \

-e ELASTICSEARCH_HOSTS=http://120.78.150.188:9200 -p 5601:5601 \

-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

退出容器,重启容器

exit

docker restart es7.8

nacos

如果用docker安装naocs如果是 2版本可能会启动不了

docker pull nacos/nacos-server:1.3.1

docker  run \

--name nacos -d \

-p 8848:8848 \

--privileged=true \

--restart=always \

-e JVM_XMS=256m \

-e JVM_XMX=256m \

-e MODE=standalone \

-e PREFER_HOST_MODE=hostname \

nacos/nacos-server:1.3.1

访问测试 http://43.138.137.168:8848/nacos

MQ

docker run \

-e RABBITMQ_DEFAULT_USER=zhuxiaoyi \

-e RABBITMQ_DEFAULT_PASS=412826zxyZXY \

--name rabbitmq \

--hostname mq1 \

-p 15672:15672 \

-p 5672:5672 \

-d \

rabbitmq:3-management

Nginx

mkdir /root/docker/nginx

mkdir /root/docker/nginx/conf

由于我们现在没有配置文件,也不知道配置什么。可以先启动一个nginx,讲他的配置文件拷贝出来

再作为映射,启动真正的nginx

docker pull nginx:1.17.4

docker run --name some-nginx -d nginx:1.17.4

docker container cp some-nginx:/etc/nginx /root/docker/nginx/conf

然后就可以删除这个容器了

docker docker rm -f some-nginx

在重新启动nginx

docker run --name nginx -p 80:80 \

       -v /root/docker/nginx/conf:/etc/nginx \

       -v /root/docker/nginx/html:/usr/share/nginx/html \

       -d nginx:1.17.4

FTP服务器

1 需要账号和密码

docker run -v /data/dav:/usr/local/nginx/html  -d -p 88:80 lutixiaya/nwebdav:latest

chmod o+w /data/dav

ip+端口访问测试 需要输入账号和密码

使用winscp 进行连接

1、点击新建站点

2、选择协议

3、输入服务器ip

4、输入端口

5、输入用户名,默认用户:admin

6、输入密码,默认密码:bash.lutixia.cn

7、登录

https://zhuanlan.zhihu.com/p/573721115  参考链接

2 无需账号和密码

在同一个文件目录下准备好这个三个文件

start-nginx.sh

#!/bin/bash

mkdirdata

dockerstopnginx_file_server

dockerrmnginx_file_server

docker run-d-p8081:8080\

--namenginx_file_server \

-v$(pwd)/data:/data \

-v$(pwd)/nginx.conf:/etc/nginx/nginx.conf \

-v$(pwd)/default.conf:/etc/nginx/conf.d/default.conf \

       nginx:stable-alpine

nginx.conf

nginx.conf

userroot;

worker_processes1;

error_log/var/log/nginx/error.logwarn;

pid/var/run/nginx.pid;

events{

worker_connections1024;

}

http{

include/etc/nginx/mime.types;

default_typeapplication/octet-stream;

log_formatmain'$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.logmain;

sendfileon;

#tcp_nopushon;

keepalive_timeout65;

#gzipon;

include/etc/nginx/conf.d/*.conf;

}

default.conf

default.conf

server{

listen8080;#端口

server_namelocalhost;#服务名

#forSSLlistenportonly

#ssl_certificate/etc/nginx/conf.d/server.pem;

#ssl_certificate_key/etc/nginx/conf.d/server-key.pem;

#ssl_protocolsTLSv1.2;

#ssl_prefer_server_cipherson;

#ssl_session_timeout5m;

#ssl_ciphersECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;

#underscores_in_headerson;

charsetutf-8;#避免中文乱码

root/data;#显示的根索引目录,注意这里要改成你自己的,目录要存在

location/{

autoindexon;#开启索引功能

autoindex_exact_sizeoff;#关闭计算文件确切大小(单位bytes),只显示大概大小(单位kb、mb、gb)

autoindex_localtimeon;#显示本机时间而非GMT时间

   }

}

chmod +x start-nginx.sh && ./start-nginx.sh`

测试一下:

echofile_server > data/file1.txt

打开浏览器 http://127.0.0.1:8081/

DockerCompose

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

sudo chmod +x /usr/local/bin/docker-compose

docker-compose --version

安装GitLab

1 下载镜像

docker pull twang2218/gitlab-ce-zh

2 启动容器

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 进入容器修改配置文件

由于进行了目录映射 也可以不在容器内部进行修改

docker exec -it gitlab bash

cd /etc/gitlab

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 重启服务

这是在容器内部重启服务

gitlab-ctl restart

gitlab是有很多组件组成的只有这些组件都运行成功了,才启动成功。

6 访问测试

http://120.78.214.226:8090

第一次登录默认是root用户 密码自己设定  不要低于8位

安装Jenkins

1 下载镜像

docker pull jenkinsci/blueocean    中文版本

2 创建目录

# mkdir /home/jenkins_home

# chown -R 1000:1000 /home/jenkins_home/

# chown -R 1000:1000 /usr/local/src/jdk/jdk1.8/

# chown -R 1000:1000 /opt/apache-maven-3.5.0/

3 运行容器

docker run \

-d \

--name jenkins \

-p 9999:8080 \

-p 8888:8888 \

-p 50000:50000 \

-v /usr/local/src/jdk/jdk1.8:/usr/local/src/jdk/jdk1.8 \

-v /opt/apache-maven-3.5.0:/opt/apache-maven-3.5.0 \

-v/home/jenkins_home:/var/jenkins_home \

jenkins/jenkins:2.222.3-centos

4 查看密码

docker exec -it jenkins bash

cat /var/jenkins_home/secrets/initialAdminPassword

b0468f2eb870422abf509fe59f74e003

5 访问测试

http://120.78.214.226:9999/

6 进行汉化 

在安装插件页面输入 chinese

7 替换插件下载地址

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 创建文件

mkdir -p /opt/postgres/postgresql

mkdir -p /opt/postgres/data

3 创建网络

docker network create sonarqube

4 运行postgres 容器

docker run --name postgres -d -p 5432:5432 --net sonarqube \

-v /opt/postgres/postgresql:/var/lib/postgresql \

-v /opt/postgres/data:/var/lib/postgresql/data \

-v /etc/localtime:/etc/localtime:ro \

-e POSTGRES_USER=sonar \

-e POSTGRES_PASSWORD=sonar \

-e POSTGRES_DB=sonar \

-e TZ=Asia/Shanghai \

--restart always \

--privileged=true \

--network-alias postgres \

postgres:latest

5 安装 sonarQube

docker pull sonarqube

6 准备文件夹

mkdir -p /opt/sonarqube

echo "vm.max_map_count=262144" > /etc/sysctl.conf

sysctl -p

7 先运行一下拷贝文件

docker run -d --name sonarqube sonarqube

docker cp sonarqube:/opt/sonarqube/conf /opt/sonarqube

docker cp sonarqube:/opt/sonarqube/data /opt/sonarqube

docker cp sonarqube:/opt/sonarqube/logs /opt/sonarqube

docker cp sonarqube:/opt/sonarqube/extensions /opt/sonarqube

8 删除容器

docker stop  sonarqube

docker rm  sonarqube

9 添加权限

chmod -R 777 /opt/sonarqube/

10 修改配置文件

vim /opt/sonarqube/conf/ sonar.properties

修改账号和密码

sonar.jdbc.username=sonar

sonar.jdbc.password=sonar

sonar.jdbc.url=jdbc:postgresql://postgres:5432/sonar

11 运行容器

docker run -d --name sonarqube -p 9090:9000 \

-e ALLOW_EMPTY_PASSWORD=yes \

-e SONARQUBE_DATABASE_USER=sonar \

-e SONARQUBE_DATABASE_NAME=sonar \

-e SONARQUBE_DATABASE_PASSWORD=sonar \

-e SONARQUBE_JDBC_URL="jdbc:postgresql://postgres:5432/sonar" \

--net sonarqube \

--privileged=true \

--restart always \

-v /opt/sonarqube/logs:/opt/sonarqube/logs \

-v /opt/sonarqube/conf:/opt/sonarqube/conf \

-v /opt/sonarqube/data:/opt/sonarqube/data \

-v /opt/sonarqube/extensions:/opt/sonarqube/extensions\

sonarqube

12测试访问

浏览器输入http://ip:9090,开始初始化数据库初始化成功后进入登录界面,账号:admin  密码:admin

轻量级容器监控

portanier

  下载  docker pull lihaixin/portainer

docker run -d -p 9000:9000 --restart=always \

-v /var/run/docker.sock:/var/run/docker.sock \

--name portainer lihaixin/portainer

访问测试  http://43.138.137.168:9000/#/home

重量级 容器监控

docker-compose.yml配置 

version: '3.1'

volumes:

  grafana_data: {}

services:

influxdb:

  image: tutum/influxdb:0.9

  restart: always

  environment:

   - PRE_CREATE_DB=cadvisor

  ports:

   - "8083:8083"

   - "8086:8086"

  volumes:

   - ./data/influxdb:/data

cadvisor:

  image: google/cadvisor

  links:

   - influxdb:influxsrv

  command:

  -storage_driver=influxdb - storage_driver_db=cadvisor -storage_driver_host=influxsrv:8086

  restart: always

  ports:

   - "8080:8080"

  volumes:

   - /:/rootfs:ro

   - /var/run:/var/run:rw

   - /sys:/sys:ro

   - /var/lib/docker/:/var/lib/docker:ro

grafana:

  user: "104"

  image: grafana/grafana

  user: "104"

  restart: always

  links:

   - influxdb:influxsrv

  ports:

   - "3000:3000"

  volumes:

   - grafana_data:/var/lib/grafana

  environment:

   - HTTP_USER=admin

   - HTTP_PASS=admin

   - INFLUXDB_HOST=influxsrv

   - INFLUXDB_PORT=8086

   - INFLUXDB_NAME=cadvisor

   - INFLUXDB_USER=root

   - INFLUXDB_PASS=root

docker-compose up -d

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,928评论 6 509
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,748评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,282评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,065评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,101评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,855评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,521评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,414评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,931评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,053评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,191评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,873评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,529评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,074评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,188评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,491评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,173评论 2 357

推荐阅读更多精彩内容