Docker安装软件

使用Dockerfile安装软件,docker安装不同软件

部署java项目

创建Dockerfile

1
2
3
4
5
6
7
8
9
10
11
12
# 基础镜像是docker仓库的java:8(也就是jdk8的意思)
FROM java:8
# 作者签名
MAINTAINER xiaoxiang
# 简化 jar 的名字路径 (左边是服务器中jar包的路径,因为当前文件是和jar包同级,所以直接写名字即可,右边是镜像中要存放jar包的路径)
COPY test.jar /test.jar
# 设置时间
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
# 执行 java -jar 命令 (CMD:在启动容器时才执行此行。RUN:构建镜像时就此行,后面的jar包路径就是上面要设置的jar包路径)
CMD java -jar /test.jar
# 设置对外端口为 8080
EXPOSE 8080

创建镜像

1
2
# 后面有个点,指定路径为当前路径的Dockerfile文件
docker build -t test .

运行jar包

  • -d代表后台运行
  • -p 8082:8082 端口映射,后一个8082是镜像的端口
  • -v 代表挂载一个宿主机目录到容器目录中,第一个是宿主机目录,第二个是容器目录
  • 第一个test/java代表是给容器的名字
  • 第二个test是上面创建镜像的名字
1
docker run -d -p 8080:8080 -v /opt/java:/opt/java --name test/java test

查看容器

1
docker ps -a

安装Mysql

1
mkdir -p /opt/data/mysql/data
1
mkdir -p /opt/data/mysql/conf.d
1
docker run -di -p 3307:3306 -v /opt/data/mysql/conf.d:/etc/mysql/conf.d -v /opt/data/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=密码 --name mysql mysql

安装Redis

1
mkdir -p /opt/data/redis/data
1
mkdir -p /opt/data/redis/conf
1
vim /opt/data/redis/conf/redis.conf
1
docker run -d -p 6379:6379 --name redis  -v /opt/data/redis/redis.conf:/etc/redis/redis.conf  -v /opt/data/redis/data:/data redis redis-server /etc/redis/redis.conf --requirepass "密码"  --appendonly yes

redis.conf

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
protected-mode yes
port 6379
tcp-backlog 511
timeout 0
daemonize yes
supervised no
pidfile /var/run/redis_6379.pid
loglevel notice
logfile /var/log/redis/redis.log
databases 16
save 900 1
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb
dir /var/lib/redis
slave-serve-stale-data yes
slave-read-only yes
repl-diskless-sync no
repl-diskless-sync-delay 5
repl-disable-tcp-nodelay no
slave-priority 100
requirepass 密码
appendonly no
appendfilename "appendonly.aof"
appendfsync everysec
no-appendfsync-on-rewrite no
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
aof-load-truncated yes
lua-time-limit 5000
slowlog-log-slower-than 10000
slowlog-max-len 128
latency-monitor-threshold 0
notify-keyspace-events ""
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
list-max-ziplist-size -2
list-compress-depth 0
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
hll-sparse-max-bytes 3000
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit slave 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
hz 10
aof-rewrite-incremental-fsync yes

安装布隆过滤器Redis

其他配置同上

1
2
3
4
5
6
docker run -p 6379:6379 \
--name redis-bloom \
-v /opt/data/redis/redis.conf:/etc/redis/redis.conf -v /opt/data/redis/data:/data \
redislabs/rebloom:2.2.2 \
/etc/redis/redis.conf --requirepass "密码" --appendonly yes \
--loadmodule "/usr/lib/redis/modules/redisbloom.so"

安装nginx

1
mkdir -p /opt/data/nginx/{conf,html,logs}
1
vim /usr/nginx/conf/nginx.conf
1
docker run --name nginx -d -p 80:80 -p 443:443 -v /opt/data/nginx/html:/usr/share/nginx/html:ro -v /opt/data/nginx/conf/nginx.conf:/etc/nginx/nginx.conf:ro  -v /opt/data/nginx/conf.d:/etc/nginx/conf.d:ro -v /opt/data/nginx/logs:/var/log/nginx nginx

nginx.conf

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;
include /usr/share/nginx/modules/*.conf;
events {
worker_connections 1024;
}
http {
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;
tcp_nodelay on;
keepalive_timeout 65;
types_hash_max_size 2048;

include /etc/nginx/mime.types;
default_type application/octet-stream;


server {
listen 80 default_server;
listen [::]:80 default_server;
server_name _;
root /usr/share/nginx/html;

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

location / {
}

error_page 404 /404.html;
location = /40x.html {
}

error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
}
# Settings for a TLS enabled server.
#
# server {
# listen 443 ssl http2 default_server;
# listen [::]:443 ssl http2 default_server;
# server_name _;
# root /usr/share/nginx/html;
#
# ssl_certificate "/etc/pki/nginx/server.crt";
# ssl_certificate_key "/etc/pki/nginx/private/server.key";
# ssl_session_cache shared:SSL:1m;
# ssl_session_timeout 10m;
# ssl_ciphers HIGH:!aNULL:!MD5;
# ssl_prefer_server_ciphers on;
#
# # Load configuration files for the default server block.
# include /etc/nginx/default.d/*.conf;
#
# location / {
# }
#
# error_page 404 /404.html;
# location = /40x.html {
# }
#
# error_page 500 502 503 504 /50x.html;
# location = /50x.html {
# }
# }

}

安装nacos

使用挂载文件的方式

1
docker run -d --name nacos -v /opt/nacos/conf/application.properties:/home/nacos/conf/application.properties -p 8848:8848 nacos/nacos-server

application.properties

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
server.servlet.contextPath=/nacos
server.port=8848
nacos.naming.empty-service.auto-clean=false
nacos.naming.empty-service.clean.initial-delay-ms=60000
nacos.naming.empty-service.clean.period-time-ms=20000
management.metrics.export.elastic.enabled=false
management.metrics.export.influx.enabled=false
server.tomcat.accesslog.enabled=true
server.tomcat.accesslog.pattern=%h %l %u %t "%r" %s %b %D %{User-Agent}i
server.tomcat.basedir=
nacos.security.ignore.urls=/,/error,/**/*.css,/**/*.js,/**/*.html,/**/*.map,/**/*.svg,/**/*.png,/**/*.ico,/console-fe/public/**,/v1/auth/**,/v1/console/health/**,/actuator/**,/v1/console/server/**
nacos.core.auth.system.type=nacos
nacos.core.auth.enabled=false
nacos.core.auth.default.token.expire.seconds=18000
nacos.core.auth.default.token.secret.key=SecretKey012345678901234567890123456789012345678901234567890123456789
nacos.core.auth.caching.enabled=false
nacos.istio.mcp.server.enabled=false
spring.datasource.platform=mysql

db.num=1
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=123456

安装elasticSearch

安装

1
docker run -d --name es -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" docker.elastic.co/elasticsearch/elasticsearch:7.6.2

配置跨域和密码

1
2
# 进入容器
docker exec -it es /bin/bash
1
2
# 编辑文件
vi config/elasticsearch.yml
1
2
3
4
5
6
7
8
9
10
11
# 名称,保证唯一
cluster.name: es-1
# 为本机ip地址,docker中为0.0.0.0
network.host: 0.0.0.0
# 打开跨域,选填
http.cors.enabled: true
http.cors.allow-origin: "*"
http.cors.allow-headers: Authorization
# 开启安全认证,选填
xpack.security.enabled: true
xpack.security.transport.ssl.enabled: true
1
2
# 重启镜像
docker restart es
1
2
3
# 设置密码,进入bin目录
# 需要为4个用户分别设置密码:elastic、kibana、logstash_system、beats_system
cd /usr/local/kibana-7.6.2-linux-x86_64/bin && ./elasticsearch-setup-passwords interactive
1
2
# 浏览器查看
192.168.0.18:9200

安装中文分词
GitHub下载

1
2
3
# 下载后解压移动到/usr/share/elasticsearch/plugins,重启
docker cp elasticsearch-analysis-ik-7.8.0/ es:/usr/share/elasticsearch/plugins
docker restart es

安装Kibana

创建配置文件

1
2
3
4
5
6
7
8
9
server.name: kibana
server.host: "0"
# elasticSearch地址
elasticsearch.hosts: [ "http://127.0.0.1:9200" ]
xpack.monitoring.ui.container.elasticsearch.enabled: true

#添加密码数据
elasticsearch.username: "elastic"
elasticsearch.password: "xxx"

安装

1
2
3
4
docker run -d --log-driver json-file --log-opt max-size=100m --log-opt max-file=2 --name kibana -p 5601:5601 -v /opt/kibana/kibana.yml:/usr/share/kibana/config/kibana.yml kibana:7.4.1

# 浏览器查看
127.0.0.1:5601

安装Oracle11g

下载Oracle 11g R2安装包

1
2
3
4
5
6
# 创建目录
mkdir -p /opt/oracle/install/database

# 解压下载的文件
unzip -d linux.x64_11gR2_database_1of2.zip /opt/oracle/install/database
unzip -d linux.x64_11gR2_database_2of2.zip /opt/oracle/install/database
1
2
# 安装,安装过程很久,可能会卡在终端,可以新开一个终端查看是否安装完成
docker run --privileged --name oracle -p 1521:1521 -v /opt/oracle/install/database:/install docker.io/jaspeen/oracle-11g
1
2
3
4
5
6
# 进入容器
docker exec -it oracle11g /bin/bash
# 切换到oracle用户
su - oracle
# 进入数据库
sqlplus / as sysdba
1
2
3
4
5
-- 创建一个用户
create user username identified by password;

-- 给用户授权
grant create session,create table,create sequence,unlimited tablespace to username;

出现数据库不能连接错误

docker出现数据库连接异常

拷贝容器中的timezone文件到本地

1
2
# 第一个名字是容器和路径,第二个点代表拷贝到当前目录下
docker cp test/java:/etc/timezone .

修改

1
Etc/CST

放回原位

1
2
# 在文件所在的目录下拷贝到容器的 /etc/下
docker cp timezone 容器名称:/etc/

Docker访问宿主机

1
vim /etc/firewalld/zones/public.xml

添加

1
2
3
4
<rule family="ipv4">
<source address="172.17.0.0/16" />
<accept />
</rule>

重启防火墙

1
systemctl restart firewalld

Docker命令自动补全

1
2
3
4
5
yum install -y bash-completion

source /usr/share/bash-completion/bash_completion

source /usr/share/bash-completion/completions/docker

设置自启

设置自启动

1
docker update --restart=always 容器id

关闭自启动

1
docker update --restart=no 容器id

关闭所有自启动

1
docker update --restart=no $(docker ps -q)

相关文章

Docker

Docker高级

Docker安装Alist+Aria2+Qbittorrentee

Docker设置代理