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

[经验分享] 初码-Azure系列-迁移PHP应用至Azure的一些实践记录和思考

[复制链接]

尚未签到

发表于 2017-6-30 06:12:22 | 显示全部楼层 |阅读模式
  最近客户在逐步迁移应用从阿里云到Azure,这次又轮到一个PHP+MySQL应用了,顺便也记一下流水账。
  需求:迁移部署在阿里云上的ECS服务器(系列2,IO优化+2核4G+50G的SSD云盘+10M带宽+Server 2012 R2+安装在操作系统上的MySQL数据库【版本不详】)到Azure上
  
  最终的方案简易描述如下:
  1、使用Azure虚拟机替代ECS服务器,使用MySQL Database on Azure替代本地MySQL
  2、从Server 2012 R2操作系统升级到Windows Server 2016操作系统
  3、为客户增加Windows下PHP Manager工具的Fast CGI PHP版本管理方式
  4、增加HTTPS支持(客户买了赛门铁克SSL证书,顺便就升级一下)
  5、将原有Web本地资源文件升级为CDN服务(实在抱歉,Azure的CDN开发工作才进展到一半,所以继续使用阿里云CDN蛤蛤)
  
  这个方案本身平淡无奇,但其中还是有2个非常有意思的地方可以思考一下,第一个就是关于云服务中PHP环境搭建,先聊一聊这个话题
  众所周知,在云服务时代之前,最火爆的就是虚拟主机(虚拟空间)了,而那个时候的虚拟机主机技术中,相当流行的一种,就是Windows宿主服务器+IIS接口开发+MySQL资源分配接口开发+SQL Server资源分配开发+Web控制面板服务开发
  这种技术发展到后期,在适配上已经做到了全能空间,即对asp、asp.net、php、java等环境进行全方位的支持,在管理上也形成了全功能的控制面板,可以对域名绑定、FTP信息、运行状态等进行管控和查询,实在是建站神器
  而从阿里云引领国内的云服务建设后,这种方式好像一夜之间消失不见了
  取而代之的是Linux虚拟机+PaaS MySQL数据库服务+推荐Linux控制面板安装PHP环境,或者是Windows虚拟机+PaaS MySQL数据库服务+环境一键安装包等,在阿里云云服务市场也是这么推荐的,在社区里面的技术讨论也围绕着这样的方式展
  这样的转变,微妙而又十分有趣
  所以呢,我要抛出一个观点,在云服务时代,对于月均预算在200元以上的用户(学生、技术爱好者、开发人员、小微企业甚至中小企业等)
  Windows Server(2008 R2+)+Fast CGI+IIS+PHP Manager是PHP环境唯一最佳选择!
  1、为何强调月均预算200以上,因为目前的云服务商的Windows Server(2008 R2+),4G以上内存的虚拟机的综合费用无法降价到200元以内,而内存不到4G,Windows Server 总感觉不得劲(注意:此处并不意味着Windows Server吃内存,只是GUI确实会耗费一些内存、带来一些内存泄露风险,你愿意的话也可以用 NoGUI版本)。
  2、在IIS6(Windows Server 2003以前)时代,受制于ISAPI的低效率,Windows下的PHP环境总是被人诟病,而IIS7以后,FastCGI+IIS方式的效率,无论如何是不输任何Linux下的PHP运行方式了
  3、如果在人才如此昂贵的今天,你还固执的认为Linux+第三方面板的管理方式要比Windows远程桌面来的先进、高效和可控的话,我表示出门向东朝鲜欢迎你
  4、PHP Manager For IIS这种PHP版本管理神器,是任何一个PHP开发者和爱好者第一眼看到都无法拒绝的东西,一目了然的参数配置,快捷的插件安装,无需重启Server的版本切换,无不是PHP开发和部署的好伴侣,更别说如今PHP版本这么混乱和多变了,可惜的是,微软也不推广,由于非常稳定,程序也4年多没更新了,一直能适配高版本的IIS,所以也越来越鲜有人知。
  5、高效的IT管理一定是云服务时代的重要话题和重要价值,如果你不选择Windows的PHP服务环境,那你就是在犯罪
  刚才说到虚拟空间的PHP环境变得越来越少,但有意思的是
  Azure中的应用服务下Web应用让这种环境搭建方式重现江湖
  话不多说,看下官网的介绍:
   DSC0000.png
  好家伙,支持的挺多,确实很有意思,而后的自动缩放、负载均衡和高可用性,这从微软的口中说出,突然觉得份靠谱,是虚拟机环境非常好的替代品
  而中文官方也很好的给出了3种环境的额外说明教程
   DSC0001.png


  • 构建 Node.JS Web 应用并部署到 Azure
  • 使用 Azure Web 应用配置 Python
  • PHP:创建并部署你的首个 Web 应用
  而当我们真的想尝试建一个Web应用的时候,更为高能的来了!!!
   DSC0002.png
   DSC0003.png
  免费
   DSC0004.png
  所以说,1元试用+F1版本的Web应用=个人永久免费1G网站空间?
  外国人就是实诚啊,这要是放在阿里云上,估计早就给玩坏了。。
  为了试验一下这个空间的效果,我们申请一个F1版本,放一个phpinfo.php试试看
   DSC0005.png
  申请成功后,可以看到默认有一个URL,也分配了一个FTP,打开这个URL会有一个默认首页
   DSC0006.png
   DSC0007.png
  于是我们在部署凭据中设置一下FTP账号密码
   DSC0008.png
  然后我们通过FileZilla Client for Windows,上传一下新建好的phpinfo.php文件到FTP
  然而,失败了。。也不知道是啥原因,无论怎么设置FTP账号密码,改变模式,甚至下载发布配置文件查看FTP账号和密码也无效,所以最后无奈下
  在Visual Studio 2017中新建了一个Web网站,然后导入了下载好的配置文件,终于可以Web Deploy成功了。。
   DSC0009.png
  发布一个phpinfo.php看看
  http://webapptest0001.chinacloudsites.cn/phpinfo.php
   DSC00010.png
  紧接着进一步观察和尝试Web应用控制台的功能
  我靠,微软简直是在技术上领先,简直就是在犯罪啊!功能也太丰富和全面了,这控制面板看的好爽,下面一个一个来过一遍
  首先是
   DSC00011.png
  微软真是太与时俱进了,竟然以技术栈的方式列出了不同的应用方式
   DSC00012.png
  各种悉心引导
   DSC00013.png
  在应用程序设置中
   DSC00014.png
  可以很全面的看到Web应用的配置信息并进行各种参数设置
   DSC00015.png
   DSC00016.png
  活脱一个Web版的IIS控制面板
  然后看到一个有趣的功能-MySQL In App
   DSC00017.png
  按照我的理解,这是一个和Web应用共享资源的迷你版MySQL PaaS服务,我们也打开试一试
   DSC00018.png
  具体怎么玩的话,可以点了解详细信息,今天就不细细深究了,因为不花钱的东西咱们不玩,只玩贵的,这免费的MySQL算什么自行车!!
  下面是一个特别好玩的Web控制台
   DSC00019.png
  一进去就提醒你,这是沙盒环境哈哈,不要做无谓的尝试
   DSC00020.png
  试了几下命令,发现挺有意思的,所有的操作系统和程序相关的东西都在D盘,也看不出来这种Web应用的资源管理和调度方式,目录结构也挺凌乱的,不知道这种凌乱是微软还是个别Azure开发人员的作风呢
   DSC00021.png
  下面是个在线编辑器
   DSC00022.png
   DSC00023.png
  也挺有意思的
  其余的一些功能,技术性和维护性较重,就不一一细述了,但可以肯定的是,仍然有很多可挖掘的技术以及运维宝藏
  言归正传,再回到我们今天的正题迁移上来
  刚才说有2个有意思的地方,另一个就是关于国内MySQL的PaaS服务了
  也是众所周知,阿里云一直标榜的最强项RDS MySQL,相比同类同配普通MySQL PaaS提升性能5倍以上,价格也更便宜,暂且不考虑MySQL的基础能力如何,对于阿里云的MySQL很强这一点,我是相信的,阿里云再没点抓手那真是很丢脸了,但也不是一骑绝尘,腾讯云的MySQL能力自从财付通的数据库技术完全开放给腾讯后,在得到了极大的提升,印象中之前朋友圈看到过一个数据库性能大赛,一直第一名的阿里云在2016年输给了腾讯云团队。。
  话扯远了,我想说的是,根据我肤浅的观察,云服务的MySQL PaaS服务能力,有如下几个进阶过程


  • 第一级,能够根据MySQL的命令和接口,封装出MySQL的PaaS服务,功能和性能完全公版化
  • 第二级,深入研究MySQL的源码和细节,能够在定制化的PaaS服务中,做较大的性能优化和提升
  • 第三级,充分融合自身的云服务以及深度开发和定制,达到更加定制化、智能化、高效化的数据高可用、快可备、热迁移的PaaS服务能力
  • 第四级,修改MySQL源码、定制出性能更强,适应场景更多的自主产权的MySQL仿版数据库,然后在细分行业发挥更大的价值和作用
  而根据我不成熟的判断,腾讯云和阿里云均已达到了第四级,而腾讯云在第三级的细节上,较阿里云还有一些差距,而Azure最早版本的MySQL服务,应该还停留在第一级,最新版本的AzureMySQL还不清楚动向,不过按照微软一贯的特点,Azure的MySQL Database on Azure服务,可用性应该还是挺高的!(我确实不是数据库专家,甚至都不专长于关系数据库的开发,以上言论如有不正确的地方,还望指出!)
  正好这次客户对MySQL的性能毫无要求哈哈,所以我也没啥好纠结的,直接建一个MySQL服务用就行了
  下面是新建过程
   DSC00024.png
   DSC00025.png
  考虑到负载不是很大,我们选择了一个MS2版本,100连接数
   DSC00026.png
  而MySQL版本则选择了5.7
  大约5分钟不到新建完毕
   DSC00027.png
  捣鼓了一下,新建了用户名和密码,哈哈哈,怎么都连不成功!!!!以前老版本控制面板还成功过, 怎么到了新控制面板就不行了。。
   DSC00028.png
  然后,额。。这全局控制面板,真的是比我想象中还要简(弱)单(智),老控制面板很多功能好像也没了
  服务器没有重启项,没有防火墙管理,没有细分权限管理,哈哈哈,微软,你搞MySQL以后,有没有得抑郁症!
  今天时间有限。。就不捣鼓了,改天问下Azure的人怎么回事吧…
  然后就是新建一个Azure虚拟机,详细的过程就不多说了,有想了解的可以参考这篇文章:《初码-Azure系列-记一次从阿里云到Azure的迁移和部署》
  既然刚才提到PHP Manager是个神器,这边也介绍一下使用方式
  首先到PHP Manager官网下载http://phpmanager.codeplex.com/releases/view/69115
  记得下载X64的版本
   DSC00029.png
  不要害怕,虽然2011年就不更新了,但是完全适配所有IIS7.5以上的版本,只是IIS10有个小BUG,需要修改注册表才能安装,详细方法参见:Windows Server 2016中,安装PHP Manager,ARR3.0或者URL Rewrite 2.0无法成功的解决办法
  然后就是下载不同的PHP版本,在http://windows.php.net/中直接下载zip包就可以了,当然了,有一些老版本的包,需要在网上自己找了,好像官网已经没有直接的下载地址了(或者我没找到)
  我的习惯是在资源管理器中按照目录和功能进行PHP包的划分
   DSC00030.png
  然后打开IIS,打开PHPManager,进行不同的PHP版本的注册,非常简单,就1个步骤
   DSC00031.png
   DSC00032.png
  然后选择PHP版本目录下的php-cgi.exe文件,就完成了注册
  而PHPManager最为神奇的是,借助IIS的Web.Config管理,可以让不同的网站,使用不同版本的PHP,你说这是不是极大的提升了IT管理效率
  好啦,今天的工作就算完成了,老规矩总结一下
  总结与思考
1、Azure的Web应用服务,确实挺好的,很好很好很好!而在细节上,也确实又一次体现了微软的技术精神和技术能力,无论从价格上还是运维上看,都是一个非常好的站长建站工具,如有申请了1元账户的个人或者小微企业客户,大可放心的尝试、学习和研究。
  2、Azure的MySQL服务,在国内看的话,确实不在第一梯队,如果想在Azure上享受到高性能的关系数据库服务,麻烦将技术栈从MySQL转变为SQL Server并购买Azure SQL服务哈哈(我刚好有个客户也有这个需求,后面会详细记录下来过程)。
  3、PHP的环境搭建,真的不用多想了,无论是想要高性能、高可用还是易维护,Windows环境都是唯一选择!一些小白们麻烦不要在技术上犯左倾错误了,LinuxPHP是没有前途的!也没有钱途!
  4、Azure的MySQL服务,真的是。。。挺弱智的。。哈哈哈,别逼我笑
  作者:张柔,发布于  博客园  与  张柔的博客
  转载请注明出处,欢迎邮件交流:zhangrou@printhelloworld.com,或者加QQ群:11444444

运维网声明 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-389505-1-1.html 上篇帖子: Azure 下篇帖子: 认识 Azure
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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