如何用 Docker 安装 Eclipse Che 和 Codenvy - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Recommended Services
Amazon Web Services
LeanCloud
New Relic
ClearDB
Mrexamo
V2EX    云计算

如何用 Docker 安装 Eclipse Che 和 Codenvy

  •  
  •   Mrexamo 2015-09-02 15:46:35 +08:00 2883 次点击
    这是一个创建于 3773 天前的主题,其中的信息可能已经有所发展或是发生改变。

    现在是时候使用 Docker 安装一个多节点 Codenvy On-Prem 和 Eclipse Che 了。

    Docker 容器包装一块软件到一个文件系统,这里面包含一切它运行的要素: code, runtime, system tools, 以及 libraries 。不管运行环境如何,容器总是保证相同的运行。容器将打包和部署转化为独立单元,使软件开发团队更容易提高 DevOps 效率。

    Codenvy 一直使用容器支持 builds, runners 以及 workspaces 好几年了。我们现在支持在容器内运行 Codenvy 。

    Eclipse Che

    Eclipse Che 是一个现代的、开放源代码的软件开发环境。它是一个通过提供结构化的工作区、项目输入、模块化扩展插件来支持 Codenvy 的引擎。 Che 可以用作桌面 IDE , RESTful 工作空间服务器,或作为一个创建新的工具 SDK 。我们现在支持一个有标签的 Docker images 启动一个默认 Eclipse Che 。

    alt 文本

    容器的容器是无状态的,重复运行将清除保存在容器内数据。你可以保存你的工作区到外部容器的 external volume 。

    如果你不想麻烦安装 volume ,还可以 snapshot 容器,并且保存一个新的 image 到本地磁盘。然后你可以启动保存的图像,它重启容器在最后保存的状态。这个过程是有状态的,但你必须等待 snapshot 写和读操作完成。

    alt 文本

    Multi-Node Codenvy On-Prem

    Codenvy On-Prem 是 Codenvy 的一个版本,你可以运行在自己的服务器上。也可以作为一个单节点(在一个主机上)或作为一个多节点系统运行 (服务跨集群以及分布在不同的主机上)。对我们来说,简单和快速安装、升级、备份,并定制 Codenvy On-Prem 一直是我们的最高目标。

    alt 文本

    你现在可以使用 Docker 安装 Codenvy On-Prem 多节点。
    虽然这安装技术是生产测试,请阅读下面的报告,你可以熟悉一下这里面的一些特定的访问控制和使用 Docker 可能会遇到的风险。这个安装程序只支持 Linux 。

    Some Special Codenvy Magic

    Codenvy On-Prem 需要八个节点。有了这个安装程序,我们在它们自己的容器启动每个节点。八大容器都是相同的从一个 specialized CentOS 7 image 的实例化。空 CentOS 容器启动后,我们调用 Codenvy ’ s bootstrap installer ,依次进行, Puppet 下载安装并配置 Codenvy 。

    alt 文本

    Codenvy 需要每个节点配置一个匹配字符串模式的 hostname 。但是为了各种容器看到对方,存在于每个容器的 /etc/hosts 文件必须随着其他容器的 IP 地址更新。这些 IP 地址将在容器启动之后才会知道。所以安装程序有一些额外的逻辑启动容器,发现它们的 IP 地址,并执行到每个容器,并随着其他容器的 IP 地址更新 /etc/hosts 文件。我们执行这项工作来创建一个可发现的、连接网络的容器,验证之后, Codenvy 引导安装开始。当重启已经保存的容器,我们做一个类似的进程利用任一个新的 IP 地址更新每个容器。

    alt 文本

    看似简单的容器。从表面上看,它们是很小的部署单位。你从一个 image 激活一个容器就搞定一切。容器执行通常是无状态的,每个执行不记得之前的执行。这意味着内部状态数据,比如我们在 LDAP 和 MongoDB 对用户的存储必须具体化。

    你可以从一个用于未来运行的容器创建新的 images 。我们已经嵌入停止和重启选项到安装脚本里,这会让你的容器状态作为 layer 写进 image 。在将来的版本中,我们将支持容器编排器 Docker Swarm ,这将给你另外一种方法具体化内部数据。

    Security & Stability Considerations

    Codenvy On-Prem 的 Docker 安装不支持单节点配置。单节点 Codenvy 打包非常打,而且 Docker 不适合在一个容器中运行数十个微服务。

    Codenvy On-Prem multi-node 所有的容器必须在特权模式下运行,这种模式允许容器以 near-root 访问进程和运行在其主机上的文件。这是必要的,有两个原因:

    1 。我们的 runner nodes 必须在 Docker 里面运行 Docker 容器。
    2 。我们使用 Puppet 执行内部配置管理,它需要访问所有节点,甚至一些等底层主机如 AppArmor 或 SELinux 的文件。

    特许模式在不同的操作系统下不稳定。你可以尝试一下。

    本文由赵帅龙编译整理

    英文原文链接: http://blog.codenvy.com/eclipse-che-codenvy-docker/

    目前尚无回复
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2319 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 24ms UTC 02:44 PVG 10:44 LAX 18:44 JFK 21:44
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86