设为首页 收藏本站
查看: 971|回复: 0

[经验分享] 我们将生活在云上-云端开发,云端部署

[复制链接]

尚未签到

发表于 2017-2-23 11:23:07 | 显示全部楼层 |阅读模式
  相信云这个概念对于专业的开发人员来说已经不是什么新名词了。这年头搞个应用不与云沾点边都拿不出手。最近在研究node.js,我在想既然node.js能将javascript作为服务器端语言来用,那么只要将js脚本提交到云上是不是就可以直接运行了呢? 答案是可以的,来看看Cloud9吧!一个node.js的在线IDE,实现云端开发和云端部署不是梦。作为一个入门级的介绍文章,我还是从hello world开始。但在我们写代码之前,我们先来看看这个云端IDE的样子:
DSC0000.png

  怎么样,是不是很酷!酷的不仅仅是这些,它支持把代码直接push到Github和Bitbucket, 还支持直接deploy你的app到heroku,joyent和window azure云上。
  下面的步骤告诉你如何实施一次云端开发和部署:
  1. 你需要至少3个帐号:Cloud9, Github/Bitbucket, Heroku/Joyent/Azure。我个人建议是Cloud9, Github, Heroku组合,因为都是免费的。注册的事情我想就不需要多说了,不过有一点是建议都用一样的用户名和密码,这样不容易忘记^_^!
  2. 登录到Cloud9,并激活Github/Bitbucket
DSC0001.png

  3. 创建一个在线工程,你可以选择新建一个或是从Git/Bit上clone一个(我相信用过Git或Hg的朋友们都知道)。
  4. 打开这个工程,如果你第一次用的话可以看一下Cloud9的演示程序(我觉得蛮不错的)
DSC0002.png

  你可以右键工程文件夹来新建一个文件(提示:IDE有一个bug就是演示完的文件,你修改了是保存不了的,所以建议你新建一个文件,然后把原来的那个删除)。之后,请贴入如下代码:



var http = require('http');
http.createServer(function(req, res) {
    res.writeHead(200, {'Content-Type': 'text/plain'});
    res.end('hello cloud9');
}).listen(process.env.PORT);
console.log('server is running on port : ' + process.env.PORT );
  代码的含义我就不解释了,不懂的朋友可以去nodejs.org上看看先。唯一需要注意的是红色部分,在云端开发最重要的一个是端口的问题。Cloud9提供了自己的测试环境端口process.env.C9_PORT,但是这个端口在heroku上是不能工作的,这个后面会说。完了你可以在ruan那个地方去debug一下看看效果。(这里我不得不说一下,我们国家的网络真是......唉!!!啥也不说了,有vpn的用vpn,有ssh的用ssh, 没有的用代理)。
DSC0003.png

  然后你访问你得到的网址看看输出结果。(这一步有可能会失败,如果你代码没有错,那么就是网络的原因)
5. 如果以上的程序测试没有问题,那么我们下一步就准备将它部署到云上去了。请猛击Deploy按钮,在出现的Tab页面中点击右上角的+号
  (
  不过在此之前还需要将我们已有的代码提交到github上面,
  > git add .
  > git commit -m "init"
  因为heroku是从github上去拽代码的)
DSC0004.png

  对于现在的cloud9来说它只支持3个云服务,heroku,joyent和Azure。每个云服务都有各自不同的配置文件,这里选择heroku来举例(因为它是免费的哦,请先注册一个)。对于heroku的云服务来说,配置还是比较简单的。只需要一个Procfile的文件(自己手动创建一个)即可,我们只需要在里面添加这样一行代码
  web: node hello_tmpl.js
  这个文件主要是告诉heroku在启动你的应用程序时,需要如何加载或执行你的文件。另外如果你用到了除nodejs核心库以外的模块,这里还需要用到一个package.json来告诉heroku帮你加载指定的模块。将所有依赖的模块都记录到这个文件中。
DSC0005.png

  如果一切正常,最终我们登录到heroku网站后,可以在账户里看到自己创建的应用程序。
DSC0006.png

  这样就可以通过url: http://hello-ace-com.herokuapp.com/ 来访问创建的应用程序了。
  到此,基本的云端开发与云端部署流程已经结束。如果在运行应用程序时出现问题,可以通过heroku的客户端程序来查看log等内容(点击这里看看)。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-346172-1-1.html 上篇帖子: 在SeaJS中实现html模板文件的加载(Temod介绍) 下篇帖子: 我们将生活在云上-云端开发,云端部署
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表