使用SAE和GitCafe搭建网站的过程讲解

所属分类: 网站运营 / 建站经验 阅读数: 75
收藏 0 赞 0 分享

在PaaS领域目前看来新浪云走的比较早,也比较成熟。相比IaaS,PaaS更能为企业或个人带来成本上的节约。本文以php为例,记录了如何在新浪云上注册创建自己的web项目,如何在本地构建模拟环境,并使用Gitcafe的自动部署功能,使得只需要进行一次git push即可将代码发布到新浪云上。不了解的朋友可以参考。

创建应用
先是各种注册。新浪云需要使用新浪微博的帐号才能登录和使用。

由于新浪云属于PaaS(即提供软件运行环境,而不是虚拟主机或者空间),收费模式是根据访问量,按量收费的,所以我们无需关注服务器的任何指标,我们要做的只是创建一个应用。目前,新浪云需要进行实名认证才能创建2个以上的应用,所以推荐进行实名认证。

创建应用的界面如下:
2016214102619866.png (695×515)

可以看到,我们的应用将被host在sinaapp.com这个域名下,我们能够设置的子域名(App name)显然是全局唯一的,先到先得。除了应用的基本信息外,还需要选择应用使用的编程语言、框架、模板等。PHP语言的框架和模板十分丰富,而Python和Java则没有什么可用的框架或者模板。我们这里使用PHP空应用,创建的的应用名假设为testapp,下面会用到。

创建好应用之后,需要配置应用所使用的各种软件或平台服务,几个比较基本的配置如下:

在应用管理-代码管理中,创建一个版本,这个版本号建议填1
在服务管理-MySQL中,开启MySQL的功能。除非你的应用不需要数据库支持,一般MySQL是肯定要开的。管理MySQL使用的是phpmyadmin。
默认情况下,在代码管理中,可以将代码打包上传到应用,或者使用SVN提交,关于SVN参见代码管理中的说明。我们的重点是使用Git进行提交。

Gitcafe上创建代码仓库
注册
为了使用Git提交代码,我们注册使用Gitcafe。因为Gitcafe可以设置自动将代码推送到新浪云上。

GitCafe是一个跟Github十分相似的代码托管平台,本人体验下来感觉还可以,除了界面绿的我扎眼外…
注册好之后,为了方便进行git提交可以配置一下公钥。找到你个人电脑如下路径的文件:

复制代码
代码如下:

cd ~/.ssh/id_rsa.pub

将其中的内容复制粘贴到Gitcafe网站的SSH公钥管理处,这样以后在提交代码的时候就不需要输入用户名和密码了。

创建仓库
我们需要创建一个仓库,这更github没有什么区别,唯一的重点在于设置自动部署到SAE
2016214102645896.jpg (304×143)

第一次使用这个功能可能需要你OAuth验证一下,这很简单。然后Gitcafe就可以fetch到你在新浪上的创建的应用和相应的版本了。选好保存即可。

目前Gitcafe对新浪的授权没有做自动刷新,这也许是新浪的Policy,这样会导致几天以后,这个授权会过期,届时可能需要重新绑定一下。希望Gitcafe能够改善一下。
创建好应用后,可以根据提示在本地初始化应用并提交初始化到Gitcafe。不过这里,为了给后面本地模拟SAE环境埋下伏笔,我对命令稍作改变:

首先在你本地合适的地方创建一个文件夹专门用来存放SAE的应用代码,比如sae:

复制代码
代码如下:

mkdir sae

然后使用如下命令:

复制代码
代码如下:

cd sae
mkdir testapp
cd testapp
mkdir 1
cd 1
git init
touch README.md
git add README.md
git commit -m 'first commit'
git remote add origin ...
git push -u origin master

上面的命令在远程仓库地址的地方留了...,你需要自己填写,这取决于你的远程仓库地址。另外值得注意的是,需要创建一个以app名命名的文件夹,而且这个文件夹下需要有一个1的文件夹,这里的1代表app的版本号,代码部分是放在1这个文件夹下的。

如果上面的步骤没有问题的话,此时由于我们创建了README.md,所以这个文件会被自动同步到新浪云上。

配置本地环境
接下来我们需要配置一个本地执行环境,以模拟SAE的运行环境,从而调试代码。从这里下载最新的模拟环境,这里以PHP环境为例

下载解压后,可以发现,模拟环境自带apache、php、redis等软件,我们需要配置sae.conf文件,下面是这个文件重要配置项的说明:

DocumentRoot sae应用的根路径,相当于我们上面创建的sae文件夹,模拟环境每次都是从这个文件夹下的文件夹来判断有哪些应用
http_port 模拟环境启动后apache所使用的http端口
mysql_* 模拟环境并没有自带mysql,需要使用你本地或者远程的mysql,所以需要在这里配置这些参数
配置好这些后,用管理员身份启动init.cmd
2016214102709778.jpg (677×443)

如果需要修改php的配置的话,可能需要修改php.sae这个文件。这个文件实际上就是一个php的配置文件,模拟器每次启动的时候,都会把php.sae的内容复制到php.ini中。不过这里可能有一个bug,对于php.sae中的配置项disable_functions不能正确的复制到php.ini中,导致无法正常使用模拟环境,不知道目前修复了没有。我的解决办法是在php.sae中把disable_functions的值留空。

模拟环境启动后,可以在本地通过http://应用名.sinaapp.com:端口的形式来访问应用,比如:http://testapp.sinaapp.com:8081

模拟环境会在代码目录下创建config.yaml或者.appconfig,这两个文件是不能通过代码包的方式上传到SAE的,否则会出错。所以,我们需要在.gitignore中忽略这两个文件,让它们不被提交到Gitcafe,于是就不会被传到SAE。

如果将来有第二个应用的话,只需要在sae目录下创建相应的app名字命名的文件夹和版本文件夹即可,模拟器会自动识别它们。当然你也可以使用模拟器的相关命令完整对应用的管理操作。

使用mysql
为了在模拟环境中使用mysql,除了上面提到的基本配置外,还有两点需要注意:

mysql数据库名需要是app_+应用名的形式,比如应用名为testapp,那么对应的mysql数据库名必须是app_testapp
在php中访问数据库需要使用SAE定义好的常量,在实际的环境中也是这样的。
下面是一个使用pdo连接数据库的代码:

复制代码
代码如下:

$dbh = 'mysql:host=' . SAE_MYSQL_HOST_M . ';port=' . SAE_MYSQL_PORT . ';dbname=' . SAE_MYSQL_DB;
$ops = array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8");
$ops = array();
return new PDO($dbh, SAE_MYSQL_USER, SAE_MYSQL_PASS, $ops);

更多精彩内容其他人还在看

网站设计之第一印象 注意用户体验

遨游互联网的人们浏览一个个网站,是决定暂时驻留还是转身离开,往往凭借的是第一印象,这和男女相亲极为相似。如果男女双方的第一印象就不好,那么搭档去喝咖啡的可能性就很小了
收藏 0 赞 0 分享

网站建设细节标示引导用户浏览

在网站建设中,有些细节值得去研究和探讨,比如如何合理的运用标示去引导用户浏览
收藏 0 赞 0 分享

网站建设的设计与网站SEO之皮毛相附

现在网站优化SEO被太多的人所重视和讨论,但是很多SEOER往往过度的注重对搜索引擎的迎合,而忽略了网站建设的用户体验和内容设计
收藏 0 赞 0 分享

百度搜索结果后面的有多少人喜欢是什么原因

这是百度正在测试的一个新功能。1月11日消息,百度分享今日开始测试将分享数据展示在百度搜索结果页。只要是嵌入了百度分享功能的网站信息出现在搜索结果中就会显示出其被分享的次数
收藏 0 赞 0 分享

依据百度近期的几次算法,站长不要再走伪原创之路

今日在SEO论坛,有人说伪原创行将毁灭,高质量网站的春天行将到来。然而这里的伪原创后面要加两个字,那就是工具,伪原创工具行将被淘汰
收藏 0 赞 0 分享

新站如何快速提升权重的六点秘诀分享

经常有朋友问起我网站权重为什么一直很低,到底有没有好的办法快速提升呢?那好现在一起荣森网安棋子儿小编给大家分享在网站维护中快速提升网站权重
收藏 0 赞 0 分享

十大网站被降权现象汇总及原因分析

网站被降权也是网络推广过程中较为常见的现象,降权的形式也各不相同,当然原因也是多种多样
收藏 0 赞 0 分享

Google AdSense 广告已停止在您的网站上投放

早上登陆网站,发现google广告竟然无法显示了,查看邮箱发现google邮箱中在最近一次对您的帐户进行的审核中,我们发现您目前展示 Google 广告的方式不符合我们的合作规范
收藏 0 赞 0 分享

优化DNS解析和拆分域名 让网站打开速度更快技巧

如何让网站打开速度更快:DNS与拆分域名(一).
收藏 0 赞 0 分享

让网站打开更快第三弹--开启压缩篇

对于网站,也有这样的压缩技术,可以让你的网页中的文本类文件瘦身,在用户完全不知情的情况下,通过gzip和deflate压缩程序有效减少了网页,让用户更快的打开网站。
收藏 0 赞 0 分享
查看更多