Docker搭建Java web环境

 

1.1.       宿主环境

选用Ubuntu 14.04(64位)作为宿主操作系统,做一下环境检查:

1)  查看当前linux内核:


Linux内核为3.13,是Docker当前推荐的UbuntuPrecise版本。

2)  查看APT系统是否支持https:


APT系统支持https。

 

1.2.       安装Docekr

1.       将Docker仓库密钥添加到本地密钥链。


2.       添加Docker仓库到APT源清单,更新和安装lxc-docker包


使用sudo apt-get update更新软件包,然后开始安装


 

2.1.       Docker容器创建

创建基于Ubuntu 14.04镜像的容器,并挂载主机/opt/software目录作为容器的数据卷。

-i:建立交互性连接,占用容器的标准输出

-t:在容器中建立一个伪终端或者终端。

-v:将主机的目录或者文件挂载为容器数据卷或者在容器中增加数据卷

进入bash shell终端,进行接下来的jdk和tomcat的安装工作。

 

2.2.       JDK安装

下载JDK到主机路径/opt/software下,由于主机目录/opt/software挂载到了容器的数据卷。则可以在容器中使用该主机目录下的文件。

以下操作都在容器内完成:

1.       安装JDK,在/opt目录下安装

tar xzvf software/jdk-8u40-linux-x64.tar.gz –C .

2.       配置环境变量

用vim编辑.bashrc文件

然后,添加一下JDK环境变量到.bashrc

#JAVA environment variable
export JAVA_HOME=/opt/jdk1.8.0_40
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
export PATH=${JAVA_HOME}/bin:$PATH

3.       重启后,检验JDK配置是否成功

java –version

如果返回JDK版本号,则表示配置正确;否则,可能配置失败。

 

2.3.       Tomcat 安装

下载Tomcat到主机路径/opt/software下,由于主机目录/opt/software挂载到了容器的数据卷。则可以在容器中使用该主机目录下的文件。

以下操作在容器中完成:

1.       安装Tomcat,安装在/opt目录下

tar xzvf software/apache-tomcat-8.0.20.tar.gz –C .

2.       配置Tomcat

用vim编辑Tomcat的启动脚本,配置系统JDK环境变量。

vi apache-tomcat-8.0.20/bin/startup.sh

然后添加JDK环境变量,TOMCAT环境变量。

JAVA_HOME=/opt/jdk1.8.0_40
JRE_HOME=${JAVA_HOME}/jre
CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
PATH=${JAVA_HOME}/bin:$PATH
TOMCAT_HOME=/opt/apache-tomcat-8.0.20

 

2.4.       创建Tomcat启动脚本

在容器根目录/ 下创建run.sh,编辑文本内容如下:

#!/bin/bash
source ~/.bashrc
sh opt/apache-tomcat-8.0.20/bin/catalina.sh run

添加apache-tomcat-8.0.20/bin/setclasspath.sh中JDK环境变量:

# JAVA environment
export JAVA_HOME=/opt/jdk1.8.0_40
export JRE_HOME=${JAVA_HOME}/jre

 

2.5.       创建image

查看运行的容器名称:

docker ps -a

将显示关闭和正在运行的所有容器,查询到容器的名字是drunk_rosalind

基于安装了JDK和tomcat的Ubuntu容器创建镜像:

docker commit –m “Added JDK Tomcat” –a “zrg” drunk_rosalind ubuntu/javaweb:v1

查看主机上的image:

docker images

主机上的所有image都会显示出来。

 

2.6.       创建容器,映射主机端口号

基于创建的视图,采用守护进程模式启动容器,将容器8080端口映射到主机58080端口。

docker run -d -p 58080:8080 --name webapp1 javaweb/webapp:v1 /run.sh

主要选择主机的49153到65535之间的端口。

查看运行的容器:

docker ps -a

可以看容器运行了29分钟,容器的8080端口映射主机的58080端口:

b861a02c5cb8        javaweb/webapp:v1       "/run.sh"           29 minutes ago      Up 29 minutes               0.0.0.0:58080->8080/tcp   webapp1

 

在容器的主机上访问:

localhost:58080


通过网络访问:使用ifconfig查看容器主机的IP


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django DRF和Docker是两个不同的技术,它们分别用于Web开发框架和容器化部署。Elasticsearch是一个分布式搜索引擎,可以用于存储、搜索和分析大量数据。 如果您想在Django DRF应用程序中使用Elasticsearch进行搜索和分析,您可以使用Elasticsearch的Python客户端库elasticsearch-py,并将其安装到您的Django应用程序中。然后,您可以编写一些视图来与Elasticsearch进行交互,并使用Docker将Elasticsearch部署为集群。 以下是一些步骤来搭建Elasticsearch集群: 1. 安装DockerDocker Compose。 2. 编写一个Docker Compose文件来定义您的Elasticsearch集群。例如,以下是一个使用3个节点的集群的示例: ``` version: '3' services: es01: image: docker.elastic.co/elasticsearch/elasticsearch:7.8.0 container_name: es01 environment: - node.name=es01 - discovery.seed_hosts=es02,es03 - cluster.initial_master_nodes=es01,es02,es03 - cluster.name=es-docker-cluster - bootstrap.memory_lock=true - "ES_JAVA_OPTS=-Xms512m -Xmx512m" ulimits: memlock: soft: -1 hard: -1 volumes: - esdata01:/usr/share/elasticsearch/data ports: - 9200:9200 networks: - esnet es02: image: docker.elastic.co/elasticsearch/elasticsearch:7.8.0 container_name: es02 environment: - node.name=es02 - discovery.seed_hosts=es01,es03 - cluster.initial_master_nodes=es01,es02,es03 - cluster.name=es-docker-cluster - bootstrap.memory_lock=true - "ES_JAVA_OPTS=-Xms512m -Xmx512m" ulimits: memlock: soft: -1 hard: -1 volumes: - esdata02:/usr/share/elasticsearch/data networks: - esnet es03: image: docker.elastic.co/elasticsearch/elasticsearch:7.8.0 container_name: es03 environment: - node.name=es03 - discovery.seed_hosts=es01,es02 - cluster.initial_master_nodes=es01,es02,es03 - cluster.name=es-docker-cluster - bootstrap.memory_lock=true - "ES_JAVA_OPTS=-Xms512m -Xmx512m" ulimits: memlock: soft: -1 hard: -1 volumes: - esdata03:/usr/share/elasticsearch/data networks: - esnet volumes: esdata01: esdata02: esdata03: networks: esnet: ``` 3. 运行Docker Compose命令来启动您的Elasticsearch集群。例如,以下命令将在后台启动集群: ``` $ docker-compose up -d ``` 4. 确认您的集群已经启动。您可以使用以下命令来检查所有节点是否已经加入集群: ``` $ curl -X GET "localhost:9200/_cat/nodes?v&pretty" ``` 5. 在您的Django应用程序中安装elasticsearch-py库。例如,以下命令将安装最新版本的elasticsearch-py: ``` $ pip install elasticsearch ``` 6. 编写一些视图来与Elasticsearch集群进行交互。例如,以下视图将获取所有Elasticsearch集群中的文档: ``` from elasticsearch import Elasticsearch from rest_framework.views import APIView from rest_framework.response import Response class ElasticsearchView(APIView): def get(self, request): es = Elasticsearch(['es01', 'es02', 'es03']) res = es.search(index='my_index', body={'query': {'match_all': {}}}) return Response(res['hits']['hits']) ``` 7. 在您的Django应用程序中定义Elasticsearch集群的连接参数。例如,以下设置将定义3个节点的Elasticsearch集群: ``` ELASTICSEARCH_DSL = { 'default': { 'hosts': [ 'es01:9200', 'es02:9200', 'es03:9200' ] }, } ``` 8. 运行您的Django应用程序并测试您的Elasticsearch视图。例如,以下命令将启动Django开发服务器: ``` $ python manage.py runserver ``` 9. 测试您的Elasticsearch视图。例如,以下命令将获取所有Elasticsearch集群中的文档: ``` $ curl -X GET "http://localhost:8000/elasticsearch/" ``` 以上是一些步骤来搭建Elasticsearch集群并在Django DRF应用程序中使用它。请注意,这只是一个示例,您可能需要根据您自己的需求进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值