如何在Docker中设定Go并部署应用

如何在Docker中设定Go并部署应用

步骤一 - 建立Dockerfile
如下的Dockerfile可以满足以上的要求:
**FROM** golang:1.6
*# Install beego and the bee dev tool*
**RUN** go get github./astaxie/beego && go get github./beego/bee
*# Expose the application on port 8080*
**EXPOSE** 8080
*# Set the entry point of the container to the bee mand that runs the*
*# application and watches for changes*
**CMD** ["bee", "run"]
第一行,
FROM golang:1.6
将Go的官方映像档案作为基础映像。该映像档案预安装了 Go 1.6 . 该映像已经把 $GOPATH 的值设定到了 /go 。所有安装在 /go/src 中的包将能够被go命令访问。
第二行,
RUN go get github./astaxie/beego && go get github./beego/bee
安装 beego 包和 bee 工具。 beego 包将在应用程式中使用。 bee 工具用语在开发中再现地重新载入我们的程式码。
第三行,
EXPOSE 8080
在开发主机上利用容器为应用程式开放8080埠。
最后一行,
CMD ["bee", "run"]
使用bee命令启动应用程式的线上重新载入。
步骤二 - 构建image
一旦建立了Docker file,执行如下的命令来建立image:
docker build -t ma-image .
执行以上的命令将建立名为ma-image的image。该image现在可以用于使用该应用程式的任何人。这将确保这个团队能够使用一个统一的开发环境。
为了检视系统上的image列表,执行如下的命令:
docker images
这行该命令将输出与以下类似的内容:
REPOSITORY TAG IMAGE ID CREATED SIZE
ma-image latest 8d53aa0dd0cb 31 seconds ago 784.7 MB
golang 1.6 22a6ecf1f7 5 days ago 743.9 MB
注意image的确切名字和编号可能不同,但是,应该至少看到列表中有 golang 和 ma-image image。
步骤三 - 执行容器
一旦 ma-image 已经完成,可以使用以下的命令启动一个容器:
docker run -it --rm --name ma-instance -p 8080:8080 \
-v /app/MathApp:/go/src/MathApp -w /go/src/MathApp ma-image

步骤一 - 建立Dockerfile 如下的Dockerfile可以满足以上的要求: **FROM** golang:1.6 *# Install beego and the bee dev tool* **RUN** go get ...

如何在idea中设定tomcat热部署

一、配置Project Structure
1
先找到软体上如图所示的图示,开启Project Structure.
2
【配置project】
这里需要注意四个地方。
1.专案名称,可以随便起。
2.New一个jdk的安装路径。
3.选一个6.0的介面。
4.专案的classes路径。
3
【配置modules】
先配置Source。点选“+”,可以增加专案。栏目中会出现专案,右侧也会出现专案。
将游标移动到专案的src上,点选上面的source按钮,进行专案的src的新增,右边会显示出来的。
4
【配置modules】
配置Path路径。
这里需要注意的就一个,配置专案的classes目录,提供输出的路径。
5
【配置modules】
配置dependence。
这里载入的是jar包。点选右边的“+”。
1.jdk的路径。
2.专案lib路径。
3.新增Tomcat的jar包。要选library格式。(jsp-api.jar ,servlet-api.jar)
END
二、配置Tomcat
点选如图所示的地方,进行进入Tomcat配置页面。
进入页面后,点选右侧的“+”。
弹出页面后,按照如图顺序找到,tomcat---》Local。
按照如图方式进行配置。
1代表名称,给配置的Tomcat取名称。
2代表配置Tomcat的安装路径。
3代表Tomcat伺服器启动后,预设开启的浏览器,根据自己习惯开启。
4代表浏览器显示路径,根据自己喜好可以改。
5和6都是预设的,不需要修改。
配置Deployment,webapp为专案的webapp,后面的名字可以自己定义,别忘了加“/”.

首先开启idea开发工具,open一个java的web专案,然后点选Run选单,选择Edit Configurations...选单,开启Run/Debug Configurations对话方块
如何在idea中设定tomcat热部署
点选对话方块左上角的加号,选择Tomcat Server,再选择Local子选单
如何在idea中设定tomcat热部署
设定个名称,如果之前没有关联过tomcat的,需要先关联一个tomcat,关联tomcat选择Application server的Configure按钮
如何在idea中设定tomcat热部署
Application Servers对话方块开启之后,点选加号,设定一个下载好的tomcat目录路径就可以关联上
如何在idea中设定tomcat热部署
在Run/Debug Configurations对话方块中,选择Deployment选项卡,对需要部署的专案档案做设定,点选加号选择Artifact,然后选择war exploded方式,这种方式是以资料夹方式部署的,而war是以war包的方式,exploded方式支援热部署,开发的时候选择exploded方式就可以了
如何在idea中设定tomcat热部署
新增完Artifact档案之后,可以设定下Application context,不设定的话,预设应用路径为根目录
如何在idea中设定tomcat热部署
然后回到Server选项卡,设定On Update action和On frame detectivation选项,都设定为Update classes and resources,表示classes档案和资原始档都更新
如何在idea中设定tomcat热部署
8
如果只设置On Update action选项,则需要每次自己手动点选更新,设定了On frame detectivation,会监测视窗,idea视窗发生切换则自动更新档案

商业版有这个功能,社群版的功能比较鸡肋,只能reload classes 从上面的图中可以看到,reload class 是在pile之后的,而Intellij没有类似储存java档案就自动pile的功能,需要手动触发下pile, ctrl+shift+f9 就会在左下角看到绿色的提...

如何在docker中部署springboot的web应用

第一步:搭建springboot的web应用,可在CMD命令列中通过mvn install命令将应用打成jar包:如demo-0.0.1-SNAPSHOT.jar
第二步:将jar包copy到centos档案系统中,指定目录示例为:/usr/local/demo-0.0.1-SNAPSHOT.jar
第三步:构建docker映象:此处以docker build方式构建

首先你要明白docker是什么,其实他就和虚拟机器一样,只是比虚拟机器占用资源更小,使用更方便,要部署应用,你可以先拉取一个LINUX的系统下来,然后用docker基于拉取的linux映象建立容器,再在容器中进行环境搭建,部署,就和在linux系统里操作是一样的。

如何在 Visual Studio 中设定部署属性

在配置管理器中启用专案部署

在 Visual Studio 中,单击主选单上的“生成”,然后单击“配置管理器”。

为每个需要从开启的解决方案进行部署的专案选中“部署”选项。

配置专案属性

  1. 在 Visual Studio 解决方案资源管理器中,右键单击要为其配置属性的专案,然后单击“属性”。

  2. 单击专案设计器中的“部署”选项卡。

  3. 按下表中所述方法配置专案属性,然后单击“确定”。

  4. 对于解决方案中的每个专案,重复执行步骤 1、2 和 3。

如何在docker里部署nodejs

下载映象,安装环境
我们先执行如下命令,启动虚拟机器:
$ boot2docker start
2014/08/18 21:22:41 Waiting for VM to be started...
...........
2014/08/18 21:23:21 Started.
2014/08/18 21:23:21 Docker client does not run on Windows for now. Please use
2014/08/18 21:23:21 "boot2docker" ssh
2014/08/18 21:23:21 to SSH into the VM instead.
如果我们的物理机记忆体低于4G,那么跑这个boot2docker可能需要手动设定记忆体占用大小:
$ boot2docker start -m=512
我们利用命令就可以进入linux虚拟机器了
$ boot2docker ssh
boot2docker: 1.1.2
master : 740106c - Thu Jul 24 03:24:10 UTC 2014
执行 docker 命令,会有一个命令列表,里面列出了所有 docker 支援的功能,列表如下:
Commands:
attach Attach to a running container
build Build an image from a Dockerfile
mit Create a new image from a container's changes
... ...
下面会对一些常用的命令进行示例说明,我们可以通过如下命令,先查询centos的映象,并把他下载下来
$ docker search centos #查询centos名字的映象
$ docker pull centos #下载官方纯净版本的centos映象
在呼叫search命令时,你会看到有好多centos包,他们都是这样的<username>/<image_name>,这些不在根目录的映象都是非官方的,是其他使用者提交到docker hub上去的,耐心等待片刻我们就可以将centos的映象拉下来了。
如果脸黑,映象又不幸被墙,那么试试加上下面的hosts:
54.234.135.251 get.docker.io
54.234.135.251 cdn-registry-1.docker.io
成功下载好centos映象之后,我们可以利用如下命令来检视映象列表:
$ docker images
REPOSITORY TAG IMAGE ID CREATED
VIRTUAL SIZE
centos centos6 b1bd49907d55 2 weeks ago
212.5 MB
centos centos7 b157b77b1a65 2 weeks ago
243.7 MB
centos latest b157b77b1a65 2 weeks ago
243.7 MB
接下来我们就利用centos7这个映象输出一段 hello world
$ docker run b15 /bin/echo 'Hello world'
Hello world
注意这里的 b15,他表示centos7这个images的id,不用全部打全,只要保证输入的id前几位能找到唯一映象即可,这点很赞。
稍微复杂一点的例子:
$ docker run -i -d -t b15 /bin/sh -c "while true; do echo hello world; sleep 1; done"
-i表示同步container的stdin,-t表示同步container的输出,-d表示deamon,以后台启动这个container,执行这个container是永远不会停止的,每一秒钟都会输出hello world。
至于什么是container,container和image的关系我们下一段再说,列出映象的历史:
$docker history image_name



  • Docker鏄粈涔Docker鐨瀹夎鍜屽嵏杞Docker涓鍏充簬闀滃儚鐨勫熀鏈搷浣
    绛旓細Docker鏄粈涔? Docker鏄竴涓櫄鎷熺幆澧冨鍣,鍙互灏嗕綘鐨勫紑鍙戠幆澧冦佷唬鐮併侀厤缃枃浠剁瓑涓骞舵墦鍖呭埌杩欎釜瀹瑰櫒涓,骞跺彂甯冨拰搴旂敤鍒颁换鎰忓钩鍙颁腑銆傛瘮濡,浣犲湪鏈湴鐢≒ython寮鍙戠綉绔欏悗鍙,寮鍙戞祴璇曞畬鎴愬悗,灏卞彲浠ュ皢Python3鍙婂叾渚濊禆鍖呫丗lask鍙婂叾鍚勭鎻掍欢銆丮ysql銆丯ginx绛夋墦鍖呭埌涓涓鍣ㄤ腑,鐒跺悗閮ㄧ讲鍒颁换鎰忎綘鎯抽儴缃插埌鐨勭幆澧冦 Docker瀹樻柟鏂囨。...
  • 缁堜簬鏈変汉鎶Docker璁叉竻妤氫簡,Docker鍏ラ棬鏁欑▼,鍘熸潵杩欎箞绠鍗...
    绛旓細Docker鏄竴涓娇鐢Go璇█寮鍙戠殑寮婧愮殑搴旂敤瀹瑰櫒寮曟搸锛岃寮鍙戣呭彲浠ユ墦鍖呬粬浠殑搴旂敤浠ュ強渚濊禆鍒颁竴涓彲绉绘鐨勫鍣ㄤ腑锛岀劧鍚庡彂甯冨埌浠讳綍娴佽鐨勬満鍣ㄤ笂銆Docker鐨杩呯寷鍙戝睍鍜屽叏鏂扮悊蹇碉紝甯嵎浜嗘暣涓狪T鐣岋紝鎴愪负浜戞椂浠g殑涓棰楁柊鏄熴侱ocker鐩告瘮浜庝紶缁熻櫄鎷熷寲鏂瑰紡鍏锋湁鏇村鐨勪紭鍔匡細鎴戜滑鍙互浠庝笅闈㈣繖寮犺〃鏍煎緢娓呮鍦扮湅鍒板鍣ㄧ浉姣斾簬浼犵粺...
  • 浣跨敤鏂扮増Golang1.18澶氭鏋勫缓鍒朵綔docker闀滃儚鐨勮俯鍧戠粡鍘
    绛旓細see 'go help modules'鍏跺疄璇寸殑鏄痝o get鍙槸涓嶇敤鏉uild浜嗭紝浠栧彧鑳鍦╣o.mod涓仛渚濊禆鍖呯浉鍏崇殑鎿嶄綔銆俫o install鏄洿鎺ュ畨瑁卲ackage锛岃繖閲屼娇鐢╣o install鏄庢樉涓嶅銆傛帉鎻′簡浜嗕互涓婁俊鎭紝灏卞彲浠ラ拡瀵规х殑瑙e喅浜嗐傛垜涔嬪墠鐨dockerfile涓彲浠ユ坊鍔犱竴涓媑o.mod鐨勫垵濮嬪寲鎿嶄綔锛屾柊鐨刦ile濡備笅锛氶棶棰樿В鍐筹紝鏋勫缓闀滃儚鎴愬姛浜嗐
  • Go璇█鐨勫紑婧愰」鐩
    绛旓細浠嬬粛锛Docker鏄竴绉嶆搷浣滅郴缁熷眰闈㈢殑铏氭嫙鍖栨妧鏈紝鍙互鍦ㄦ搷浣滅郴缁熷拰搴旂敤绋嬪簭涔嬮棿杩涜闅旂锛屼篃鍙互绉颁箣涓哄鍣ㄣ侱ocker鍙互鍦ㄤ竴鍙扮墿鐞嗘湇鍔″櫒涓婂揩閫熻繍琛屼竴涓垨澶氫釜瀹炰緥銆備緥濡傦紝鍚姩涓涓狢ent OS鎿嶄綔绯荤粺锛屽苟鍦ㄥ叾鍐呴儴鍛戒护琛屾墽琛屾寚浠ゅ悗缁撴潫锛屾暣涓繃绋嬪氨鍍忚嚜宸卞湪鎿嶄綔绯荤粺涓鏍烽珮鏁堛2锛golang椤圭洰 缃戝潃涓 https://...
  • 寰湇鍔″熀纭鏈嶅姟涔docker绡
    绛旓細Docker 浣跨敤 Google 鍏徃鎺ㄥ嚭鐨 Go 璇█ 杩涜寮鍙戝疄鐜帮紝鍩轰簬 Linux 鍐呮牳鐨 cgroup锛宯amespace锛屼互鍙 AUFS 绫荤殑 Union FS 绛夋妧鏈紝瀵硅繘绋嬭繘琛屽皝瑁呴殧绂伙紝灞炰簬 鎿嶄綔绯荤粺灞傞潰鐨勮櫄鎷熷寲鎶鏈傜敱浜庨殧绂荤殑杩涚▼鐙珛浜庡涓诲拰鍏跺畠鐨勯殧绂荤殑杩涚▼锛屽洜姝や篃绉板叾涓哄鍣ㄣ傛渶鍒濆疄鐜版槸鍩轰簬 LXC锛屼粠 0.7 鐗堟湰浠ュ悗寮濮嬪幓闄 LXC...
  • go-fastdfs瀹夎
    绛旓細瀹樻柟鏂囨。 docker go-fastdfs瀹夎 淇敼瀹瑰櫒閲岄潰鐨刦astdfs閰嶇疆鏈2绉嶆柟娉 濡傛灉鎯抽氳繃curl璁块棶fastdfs鐨勮瘽锛岄渶瑕佸湪cfg.json閲岄潰浣犳坊鍔犵櫧鍚嶅崟銆備娇鐢╨ocalhost鎴127.0.0.1鏄笉琛岀殑 娣诲姞172.17.0.1锛岃繖鏄docker鐨榛樿鍦板潃銆傜ず渚 杩欎釜api鍙互鏌ョ湅fastdfs鐨勬枃浠跺瓨鍌ㄤ俊鎭/group1/stat鐨刧roup1鏄垎缁勭殑鍚嶇О锛...
  • 姊呮灄鍗庣璺敱璁剧疆ipv6 DDNS
    绛旓細涓轰簡纭繚澶栫綉鍙互閫氳繃IPv6璁块棶锛岄噰鐢―DNSv6鏈嶅姟锛屽DNSPOD锛屼负浣犵殑鍩熷悕娣诲姞AAAA璁板綍锛屾寚鍚戞湇鍔″櫒鐨処Pv6鍦板潃銆傚悓鏃讹紝鍒╃敤ddns-go宸ュ叿杩涜鍔ㄦ佹洿鏂帮紝璁╁缃戝缁堣兘閫氳繃浣犵殑鍩熷悕璁块棶銆鍦ㄨ缃鏂归潰锛屼娇鐢Docker杩愯ddns-go鏈嶅姟锛屽懡浠ゆ槸锛歴udo docker run -d --name ddns-go --restart=always --net=host -v ...
  • Docker鍩虹
    绛旓細Docker 鏄竴涓紑婧愮殑搴旂敤瀹瑰櫒寮曟搸锛屽熀浜Go 璇█ 骞堕伒浠 Apache2.0 鍗忚寮婧愩侱ocker 鍙互璁╁紑鍙戣呮墦鍖呬粬浠殑搴旂敤浠ュ強渚濊禆鍖呭埌涓涓交閲忕骇銆佸彲绉绘鐨勫鍣ㄤ腑锛岀劧鍚庡彂甯冨埌浠讳綍娴佽鐨 Linux 鏈哄櫒涓婏紝涔熷彲浠ュ疄鐜拌櫄鎷熷寲銆傚鍣ㄦ槸瀹屽叏浣跨敤娌欑鏈哄埗锛岀浉浜掍箣闂翠笉浼氭湁浠讳綍鎺ュ彛锛堢被浼 iPhone 鐨 app锛,鏇撮噸瑕佺殑鏄鍣...
  • 涓轰粈涔go璇█寮鍙docker
    绛旓細Goroutine 鍜 channel 浣垮緱缂栧啓楂樺苟鍙戠殑鏈嶅姟绔蒋浠跺彉寰楃浉褰撳鏄擄紝寰堝鎯呭喌涓嬪畬鍏ㄤ笉闇瑕佽冭檻閿佹満鍒朵互鍙婄敱姝ゅ甫鏉ョ殑鍚勭闂銆傚崟涓 Go 搴旂敤涔熻兘鏈夋晥鐨勫埄鐢ㄥ涓 CPU 鏍革紝骞惰鎵ц鐨勬ц兘濂姐傝繖鍜 Python 涔熸槸澶╁¥涔嬫瘮銆傚绾跨▼鍜屽杩涚▼鐨勬湇鍔$绋嬪簭缂栧啓璧锋潵骞朵笉绠鍗曪紝鑰屼笖鐢变簬鍏ㄥ眬閿 GIL 鐨勫師鍥狅紝澶氱嚎绋嬬殑 Python...
  • 濡備綍杩涜Docker婧愮爜璋冭瘯
    绛旓細缁忚繃鐮旂┒docker鐨勫畼鏂圭紪璇戣剼姝ワ紝鍙戠幇鏈湴缂栬瘧涔熷緢绠鍗曪紝鍙渶瑕鍦╠ocker婧愮爜鐨勭洰褰曚笅鎵ц濡備笅鍛戒护鍗冲彲锛./hack/make.sh binary 涓婇潰杩欐潯鍛戒护灏卞彧浼氱敓鎴恉ocker鐨勪簩杩涘埗鏂囦欢锛屼笉杩囪偗瀹氫笉浼氳繖涔堥『鍒╃殑锛屾墽琛岃繖涓懡浠や綘灏变細鍙戠幇閿欒銆傚鏋滅涓娆℃墽琛屾姤鐨勯敊璇簲璇ユ槸鎵句笉鍒扮浉搴旂殑go渚濊禆鍖呫傞偅涔堢幇鍦ㄥ氨寮濮嬭В鍐崇涓...
  • 扩展阅读:如何彻底隐藏dock栏 ... 为什么docker被淘汰了 ... docker启动容器如何能进入 ... docker常用的十个命令 ... 自学docker入门教程 ... docker所有命令大全 ... 尽量少用docker ... docker面试题 ... docker被禁 ...

    本站交流只代表网友个人观点,与本站立场无关
    欢迎反馈与建议,请联系电邮
    2024© 车视网