怎么在docker容器中安装一个java开发环境?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
docker安装tomcat
下载tomcat(可以指定版本号,这里默认安装最新的版本哈,指定版本号示例 docker pull tomcat:9.0.37 )
[root@localhost ~]# docker pull tomcat:9.0.37
启动
[root@localhost ~]# docker run -d -p 8080:8080 --name tomcat01 tomcat
上面运行后发现不能访问 容器http://192.168.32.128:3355/(我的示例),请看下面分析
(阿里的某些容器,如tomcat的镜像的webapp文件夹是空的,在webapps.dist里面,所以注意要将webapps.dist文件复制到webapps的目录),如图所示
#进入容器目录 [root@localhost ~]# docker exec -it tomcat01 /bin/bash #切换到webapps.dist文件夹 root@77e211d23175:/usr/local/tomcat# cd webapps.dist #复制文件 root@77e211d23175:/usr/local/tomcat# cp -r webapps.dist/* webapps
再次重新访问 http://192.168.32.128:8080/ 即可(注意端口号是docker的)
这里顺便可以把修改后的tomcat作为一个新的容器,以免下一次再复制文件(e8c58b381b99 是tomcat容器id)
[root@localhost ~]# docker commit -m="完善webapps应有的文件" -a="张晓祥" e8c58b381b99 tomcat01:9.0.37
官方安装方式 https://www.elastic.co/guide/en/elasticsearch/reference/7.5/docker.html
下载镜像
[root@localhost ~]# docker pull elasticsearch:7.9.0
创建网络,就是起个名字,如esnet
[root@localhost ~]# docker network create esnet
单节点运行(没有配置集群)
[root@localhost ~]# docker run -d --name elasticsearch --net esnet -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" elasticsearch:7.9.0
查看是否运行成功(如果还在启动会报 curl: (56) Recv failure: 连接被对方重设),当然也可以使用浏览器测试(注意把防火墙关闭了)
[root@localhost ~]# curl localhost:9200
启动成功返回示例
下载镜像
[root@localhost dcoekrdata]# docker pull mysql:8.0.21
运行(-d后台运行,-v数据挂载 -e环境配置)
[root@localhost dcoekrdata]# docker run -d -p 3306:3306 -v /home/dockerdata/mysql/conf:/etc/mysql/conf.d -v /home/dockerdata/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root --name root mysql:8.0.21
使用Navicat测试一下即可.
注意这个需要安装3个镜像才算OK哈,参考文档
https://www.jb51.net/article/202117.htm
1:安装mq
[root@localhost dcoekrdata]# docker pull rocketmqinc/rocketmq:4.3.2
运行mq服务器
docker run -d -p 9876:9876 -v /home/dockerdata/mq/namesrv/logs:/root/logs -v /home/dockerdata/mq/namesrv/store:/root/store --name rmqnamesrv -e "MAX_POSSIBLE_HEAP=100000000" rocketmqinc/rocketmq:4.3.2 sh mqnamesrv
2:安装broker
[root@localhost dcoekrdata]# docker pull rocketmqinc/rocketmq-broker:4.5.0-alpine-uid
配置broker
[root@localhost dcoekrdata]# cd /home/dockerdata/mq [root@localhost mq]# mkdir broker [root@localhost mq]# cd broker/ [root@localhost broker]# touch broker.conf [root@localhost broker]# vi broker.conf
配置文件(brokerIP1 =192.168.32.128是云服务器的公网IP,或者虚拟机Linux的IP,本文只是我的示例)
terName = DefaultCluster brokerName = broker-a brokerId = 0 deleteWhen = 04 fileReservedTime = 48 brokerRole = ASYNC_MASTER flushDiskType = ASYNC_FLUSH brokerIP1 =192.168.32.128
启动broker
docker run -d -p 10911:10911 -p 10909:10909 -v /home/dockerdata/mq/broker/logs:/root/logs -v /home/dockerdata/mq/broker/store:/root/store -v /home/dockerdata/mq/broker/broker.conf:/opt/rocketmq-4.3.2/conf/broker.conf --name rmqbroker --link rmqnamesrv:namesrv -e "NAMESRV_ADDR=namesrv:9876" -e "MAX_POSSIBLE_HEAP=200000000" rocketmqinc/rocketmq:4.3.2 sh mqbroker -c /opt/rocketmq-4.3.2/conf/broker.conf
3:安装控制台rocketmq-console-ng
[root@localhost broker]# docker pull styletang/rocketmq-console-ng:1.0.0
启动控制台(注意IP地址)
[root@localhost broker]# docker run -e "JAVA_OPTS=-Drocketmq.namesrv.addr=192.168.32.128:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" -p 8080:8080 -t styletang/rocketmq-console-ng:1.0.0
看完上述内容,你们掌握怎么在docker容器中安装一个java开发环境的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。