文档章节

ubuntu13.04通过lxc搭建容器java运行环境

voyage1314
 voyage1314
发布于 2013/12/17 19:11
字数 1224
阅读 3392
收藏 84

step1:安装lxc

sudo apt-get install lxc

说明:由于在ubuntu中通过apt-get安装lxc会自动安装lxc依赖的其他软件,debootstrap,lvm2,cgroup-lite等。

step2:lxc宿主主机配置

首先介绍几个文件夹(默认通过apt-get安装将自动生成以下文件/文件夹)

  1. /etc/lxc/default.conf

    创建容器时若未指定配置文件,则默认使用这个default.conf作为该容器的配置文件

  2. /usr/share/lxc/templates/

    该目录下保存了LXC支持的各种发行版的linux模板,通常有:


  3. /var/lib/lxc/

    这个目录是用来存放容器实例的,默认情况下该文件夹只有管理员才有权限访问读写其中文件

  4. /var/cache/lxc/

    第一次创建容器,需要下载一个mini版的容器系统,会花很长时间,创建好后,将会在该目录下创建缓存,再次创建直接采用缓存无须再网上下载,对于我的需求,我比较喜欢用lxc-clone,所有应用的容器几乎都是相同的配置,所以克隆不仅节省时间还省去大量配置的繁琐

step3:检验lxc是否已安装好

lxc-verison

如果显示 lxc version: x.x.x表示安装成功。这里x表示版本号,我安装的是lxc version:0.9.0

lxc-checkconfig

按理说所有选项都应该是enable,但是User namespace:missing,别捉急,这影响不大。有人说是内核配置的问题,有人说只在ubuntu32位系统出现。下面这段话是一个外国博友写的:

step4:创建第一个容器master

创建一个名为master的容器,采用ubuntu作为模板注意这里别忘了加sudo,不然会报错的

sudo lxc-create -t ubuntu -n master

-t : 创建的虚拟机模板名称,默认为ubuntu 12.04最小安装版,非常小

-n : 创建的虚拟名称,需要指定
  
-f : 指定配置文件  

-B : 虚拟机磁盘的系统,为了控制单个虚拟机的磁盘容量限制。

--lvname :虚拟机使用卷名,默认使用虚拟机名 
 
--vgname :卷组名称,这个一定要有,默认名称为lxc,可以单独指定。
          若不指定此选项,则要求名称为lxc的卷组已经存在,否则,请指定已经卷组名

--fstype :文件系统类型,默认为ext4类型  

--fssize :磁盘容量,默认为1G,单个应用所占有磁盘空间,一般安装之后,除了系统文件等,也就剩下500M作用可以使用。

第一次创建会花一些时间,创建完成后,会提示创建成功,默认的用户名和密码都是ubuntu

sudo lxc-start -n master -d
sudo lxc-console -n master

以守护进程开启master容器,然后进入控制台,输入用户名和密码ubuntu,现在看到的目录是这个容器的目录,无法访问宿主主机的目录,对于用户来说相当于是一台完整的服务器。

退出控制台【ctrl+a q】

step5:在容器中搭建java环境:jdk+tomcat

首先去官网下好jdk和tomcat和你自己系统对应的版本,我这里是jdk1.7.0_45.zipapache-tomcat-8.0.0-RC5.tar.gz

新建文件夹

mkdir /var/lib/lxc/master/rootfs/usr/local/java

移动上面两个文件到java目录下并解压,tomcat文件夹重命名为tomcat。注意解压的时候可能有权限问题,使用sudo chmod -R 755 filename修改文件权限。

接下来的配置都是在容器中进行,命令行进入容器控制台。

配置环境变量:

sudo vim /etc/profile

在最后加上你的jre的路径,tomcat的路径等

比如我的是在/usr/local/java/jdk1.7.0_45,/usr/local/java/tomcat,这里的根目录是容器的根目录,所以环境变量配置为:

export JAVA_HOME=/usr/local/java/jdk1.7.0_45
export CATALINA_HOME=/usr/local/java/tomcat
export TOMCAT_HOME=/usr/local/java/tomcat
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib:${CATALINA_HOME}/lib
export PATH=${JAVA_HOME}/bin:$PATH:${CATALINE_HOME}/bin

退出保存,执行以下命令生效

source /etc/profile

检验是否生效

echo $PATH

如果输出你的jdk路径表示已生效

启动tomcat

sh /usr/local/tomcat/bin/startup.sh

顺便看看8080端口开启没

netstat -nl | grep 8080


输入网址:http://localhost:8080

如果出现tomcat的欢迎页面,大功告成





© 著作权归作者所有

共有 人打赏支持
voyage1314
粉丝 7
博文 9
码字总数 6947
作品 0
杨浦
程序员
私信 提问
加载中

评论(7)

netkiller-
netkiller-
不错,有时间研究一下
Neo
Neo

引用来自“neo-chen”的评论

不太理解他的功能,跟 chroot 有相同之处??好像类似 jail(FreeBSD)

没错,lxc跟jail是很像,不过lxc共用的东西更多,jail貌似连内核也可以虚拟化,但是lxc要共用系统内核
小鸽子咕噜
小鸽子咕噜
直接docker就可以啊,都是用的lxc,cgroup
guardamo
guardamo
有点搞不懂,为什么不用jvm,而自己搭容器呢?
netkiller-
netkiller-
不太理解他的功能,跟 chroot 有相同之处??好像类似 jail(FreeBSD)
动弹
动弹
docker 可以简化过程
jingdor
jingdor
安装 http://lxc-webpanel.github.io/ 图形化配置 lxc
Ubuntu下搭建JAVA运行环境

(一)Linux操作系统安装(详细信息参见:http://my.oschina.net/u/1458864/blog/366665) 1.安装Oracle VM VirtualBox 2.安装vagrant 3.下载box 4.vagrant添加box到虚拟机中(http://my.osch...

飓风2000
2015/01/27
0
2
使用Docker在本地搭建Hadoop分布式集群

学习Hadoop集群环境搭建是Hadoop入门必经之路。搭建分布式集群通常有两个办法: 要么找多台机器来部署(常常找不到机器) 或者在本地开多个虚拟机(开销很大,对宿主机器性能要求高,光是安装...

Carl_
2015/07/24
0
2
几步搭建基于Docker的Tomcat运行环境!

Docker旨在提供一种应用程序的自动化部署解决方案,在 Linux 系统上迅速创建一个容器(轻量级虚拟机)并部署和运行应用程序,并通过配置文件可以轻松实现应用程序的自动化安装、部署和升级,非...

技术小能手
06/08
0
0
Docker搭建Hadoop集群

在学习Hadoop过程中,想要搭建Hadoop分布式集群,往往需要几台服务器或者再一台机器上搭建几台虚拟机;这两种方式搭建Hadoop集群都不是很方便,个人很少自己拥有几台服务器,或者电脑内存够大...

凌得涂
05/15
0
0
Hinernate中获得数据库连接池的方式及应用

Hibernate可以与任何一种java应用的运行环境集成。Java应用的运行环境可分为两种。 (1)受管理环境(Managed environment):由容器负责管理各种共享资源(如线程池和数据库连接池),以及管理...

_守望者_
2014/04/22
0
0

没有更多内容

加载失败,请刷新页面

加载更多

phpstorm xdebug 配置

xdebug方便了调试代码,比起一个一个地方的打印结果还是debug看的更明白下面介绍下maxOS系统下的debug配置 下载 https://xdebug.org/download.php 点击红线部分进入,粘贴phpinfo()信息推荐适...

被猪拱了的JAVA
24分钟前
2
0
Golang学习笔记(1)

基本知识 golang的文件格式以go结尾。 运行方式 go run main.go 用于开发调试使用 编译成二进制文件 go build main.go 会生成一个可执行的二进制文件 变量 变量定义的形式 Golang的变量定义有...

ExtreU
38分钟前
1
0
基于Kafka构建事件溯源模式的微服务

概要 本文中我们将讨论如何借助Kafka实现分布式消息管理,使用事件溯源(Event Sourcing)模式实现原子化数据处理,使用CQRS模式(Command-Query Responsibility Segregation )实现查询职责...

架构师springboot
44分钟前
1
0
git上传项目步骤

https://blog.csdn.net/m0_37725003/article/details/80904824

fame_yao
45分钟前
1
0
NOOBS自定义安装多系统

一、预置条件: 宿主系统是win10_x64 virtual box 虚拟机,安装了centos7 树莓派的系统安装工具:NOOBS_v2_9_0.zip,镜像文件 二、根据镜像文件生成boot.tar.xz 和root.tar.xz 1、设置共享目...

mbzhong
55分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部