在Azure上部署IPv6的App通过IOS App Store审核
随着中国企业出海Go Global,越来越多的用户开始在Global Azure部署自己的应用。由于对Global Azure功能和文档的不熟悉,使用过程中或多或少遇到了一些坑。事实上呢,这些并不是坑的坑是完全可以解决。这篇博客就是一个真实的客户案例。
客户需求
客户需要在Azure海外region部署自行研发的app后端服务器,这之后客户会向IOS App Store提交App的审核
目前问题
客户在Azure上部署了虚机但是没法分配ipv6的地址,客户还尝试配置IPv6隧道但是也不work。
背景分析
自2016年6月开始,所有提交给Apple App Store的app都必须支持IPv6-only的networking。需要注意的是,这个要求是面向App客户端代码的(https://developer.apple.com/library/content/documentation/NetworkingInternetWeb/Conceptual/NetworkingOverview/UnderstandingandPreparingfortheIPv6Transition/UnderstandingandPreparingfortheIPv6Transition.html#//apple_ref/doc/uid/TP40010220-CH213-SW1)而并不是说app的后端服务器必须有IPv6的地址,注意留心以下的截图。

上述Apple文档的链接里也给出了常见的App编程上的错误导致IPv6审核被reject以及相应的best practise,比如避免在源代码和配置文件里hardcode了IP地址,避免使用了只支持IPv4的API和库等等。这里,建议开发同学在开发初期读一下整篇文档并在测试阶段按文档章节“Test for IPv6 DNS64/NAT64 Compatibility Regularly”进行测试。
在本案中,由于APP提交审核的阶段项目已经结尾没有时间也没有人力来重新改动调试代码。全部的压力就都到了负责部署的运维团队。好在Azure Global其实已经支持部署IPv6的应用,本文会step by step的讲解在Azure中如何部署基于Windows+IIS的IPv6网站以及基于RHEL+Nginx的IPv6网站
Azure中的IPv6架构
我们先看一下在Azure中一个IPv6网站的架构图:

客户端可与public facing 的 Azure Load Balacner公共 IPv4 或 公共 IPv6 地址通信。 Load Balancer则将 IPv6 数据包路由到 VM 的私有 IPv6 地址。
这里需要着重指出的是,LB的IPv6是公有地址,也就是可以用在你的网站的域名管理里的A Record. 而虚机的IPv6则是私有地址,客户端不能通过虚机的这个地址来访问网站及虚机。由此,服务器端的安全性得到了很好的保障。
在Azure上部署
目前Azure的网站上对这个架构服务器提供了三种部署方法,Powershell,Azure CLI 以及ARM模板。对于Portal则列出了由于“无法在 Azure 门户中添加 IPv6 负载均衡规则”而无法支持的限制。然而实测发现Portal上目前已经支持部署这样一套架构了。这里考虑到快速部署的需求采用了ARM模板的方式。同时在上述架构中我们还添加了跳板机,用于在虚机中的配置工作。
Windows+IIS
ARM模板文件可以从以下Link下载:https://ipv6.blob.core.chinacloudapi.cn/template 文件名:windowsipv6.json
这里我们采用了Windows 2012 R2 Datacenter的image,大家可以根据需要改动以下的代码
"storageProfile": {
"imageReference": {
"publisher": "MicrosoftWindowsServer",
"offer": "WindowsServer",
"sku": "2012-R2-Datacenter",
"version": "latest"
},
模板的部署也有Portal,Powershell和CLI三种方式。这里Demo了Azure Portal 的Templates 功能
1. 上传模板

点击“Add”选项,在“Add general information”处填写模板的名字,在“Add template”处把上文模板的内容复制黏贴进去。随后,点击“OK”保存模板。

2. 按模板部署系统
接下来开始部署系统,选定上一步保存的模板,点击“Deploy”选项

填写所需的参数并点击“Purchase”选项

3. 部署成功之后记得远程RDP后端的虚机开启IIS功能,具体步骤可以参照http://jingyan.baidu.com/article/b24f6c82c504d686bfe5da3d.html。
因为我们模板里做了Port在50001和50002的NAT规则,RDP的时候记得要采用相应的Port
4. 部署成功后,可以在任何的浏览器里键入IPv4的DNS或IPv4ip来验证网站的IPv4的connectivity。
但是对于IPv6的验证,只有浏览器的网络环境支持IPv6才可以通过键入IPv6的DNS或者[IPv6ip]进行验证。如果网络环境不支持,可以通过http://ipv6-test.com/validate.php进行IPv6验证

可以看到以上的网站http://bw6.southeastasia.cloudapp.azure.com/ 以及IPv6地址2603:1040:3d4通过了下图的IPv6网站测试。

RHEL+NGINX
ARM模板文件可以从以下Link下载:https://ipv6.blob.core.chinacloudapi.cn/template 文件名:rhelipv6.json (这里我们采用了RHEL6.8的OS Image)
整个的模板部署过程和上文windows+iis是一样的。这里重点讲一下部署之后虚机内部的配置。
1. SSH连入虚机,同样因为我们模板里做了Port在50001和50002的NAT规则,SSH的时候记得要采用相应的Port
2. 部署Nginx,顺序运行以下命令
- sudo vi /etc/yum.repos.d/nginx.repo (若部署其他的linux系统,请参照https://www.nginx.com/resources/admin-guide/installing-nginx-open-source/ 决定以下文本内容)
[nginx]
name=nginx repo
baseurl=http://nginx.org/packages/mainline/rhel/6/$basearch/
gpgcheck=0
enabled=1
- sudo yum install epel-release
- sudo yum install nginx
- sudo ifdown eth0 && sudo ifup eth0
sudo vi /etc/sysconfig/network
NETWORKING_IPV6=yes
- sudo vi /etc/sysconfig/network-scripts/ifcfg-eth0 (在文件中加入以下内容)
IPV6INIT=yes
DHCPV6C=yes
sudo vi /etc/nginx/conf.d/default.conf (确保以下内容加入在default.conf中)
listen [::]:80;
listen 80;
- sudo service niginx start
sudo ip6tables -I INPUT -p tcp --dport 80 -j ACCEPT
- sudo iptables -I INPUT -p tcp --dport 80 -j ACCEPT
- sudo service network restart
3. 按windows章节IPv6网站验证方法开始验证


http://blog4rh.southcentralus.cloudapp.azure.com/ ,IPv6 2a01:111:f100:4001::4625:a037 确认·可以连接。
改进
在以上的部署过程中,不管是Linux还是Windows都涉及到了post-deployment的配置,比如配置IIS,Nginx,配置DHCP等等的工作。我们可以把这部分工作作为虚机extension资源放入ARM模板从而达到全自动化快速部署的需求
提示
RHEL6.8+NGINX是需要最多额外配置的IPv6组合, 我们还测试了windows+nginx,ubuntu16+nginx等组合都能顺利部署成功IPv6的网站,具体部署可以参考https://docs.microsoft.com/en-us/azure/load-balancer/load-balancer-ipv6-for-linux。比较有趣的是,在不同nginx版本测试的过程中,我们发现个别Nginx的版本对IPv6支持上存在bug,大家需要留意这点
在Azure上部署IPv6的App通过IOS App Store审核的更多相关文章
- 在 Windows Azure 上部署预配置 Oracle VM
Microsoft 和 Oracle 近期宣布建立战略合作伙伴关系,基于此,我们将通过 Windows Azure 镜像库推出多种常用的 Oracle 软件配置.即日起,客户可以在 Windows S ...
- Azure上部署FTP服务
FTP是个比较复杂的协议,其协议分为控制层和数据层,工作模式分为主动和被动两种模式. 在默认的Active模式下其工作原理如下: 可以看到,客户端发起FTP的请求道服务器端,FTP的端口是21.用户在 ...
- Azure上部署Barracuda WAF集群 --- 2
前面一篇文章讲了如何在Azure上部署Barracuda.这篇文章聊一聊如何配置Barracuda. License 向Barracuda的销售人员申请WAF的License.得到License后打开 ...
- 不可或缺 Windows Native (25) - C++: windows app native, android app native, ios app native
[源码下载] 不可或缺 Windows Native (25) - C++: windows app native, android app native, ios app native 作者:web ...
- 在 Azure 上部署 Asp.NET Core Web App
在云计算大行其道的时代,当你要部署一个网站时第一选择肯定是各式各样的云端服务.那么究竟使用什么样的云端服务才能够以最快捷的方式部署一个 ASP.NET Core的网站呢?Azure 的 Web App ...
- [文章存档]Azure上部署的java app在向第三方服务传送中文时出现乱码
https://docs.azure.cn/zh-cn/articles/azure-operations-guide/app-service-web/aog-app-service-web-java ...
- 【翻译】使用Visual Studio在Azure上部署Asp.Net Core Web应用
配置运行环境 Install the latest Azure SDK for Visual Studio. The SDK installs Visual Studio if you don't a ...
- 在公有云AZURE上部署私有云AZUREPACK以及WEBSITE CLOUD(一)
(一)前言 本文主要介绍了实践部署AzurePack的Website Cloud的过程.在部署之前, 首先要对AzurePack有个基本的了解. Azure Pack是微软的私有云方案,具有弹性. ...
- 在 Windows Azure 上部署并定制化 FreeBSD 虚拟机镜像
发布于 2014-12-11 作者 陈阳 FreeBSD 基础镜像现已登陆中国的 VM Depot! 对于青睐 BSD 而非 Linux 的开源爱好者来说,这无疑是个好消息.同时,随着该基础镜像 ...
随机推荐
- 【机器学习】人工神经网络ANN
神经网络是从生物领域自然的鬼斧神工中学习智慧的一种应用.人工神经网络(ANN)的发展经历的了几次高潮低谷,如今,随着数据爆发.硬件计算能力暴增.深度学习算法的优化,我们迎来了又一次的ANN雄起时代,以 ...
- netty(三) 组件介绍
netty各组件说明:channel ----- SocketEventLoop -------控制流,多线程处理,并发channelFuture ------- 异步通知 channel:主要是实现 ...
- 发现AspNet.Core版本控制库Bug一枚,你还想入坑?
我,博客写作小白一枚,注册账号多年却未曾留下只言片语,在潜水的这些年里从大家的博客中收获了很多新的知识忽觉惶恐心有不安,是时候给大家分享一些我的经验和教训了.嗯嗯,实话告诉大家前面的话的都是来凑字数的 ...
- 利用Angular实现多团队模块化SPA开发框架
0.前言 当一个公司有多个开发团队时,我们可能会遇到这样一些问题: 技术选项杂乱,大家各玩各 业务重复度高,各种通用api,登录注销,权限管理都需要重复实现(甚至一个团队都需要重复实现) 业务壁垒,业 ...
- python 批量修改数字类的文件名
今天碰到一个小问题,下载音频的时候,文件名的名字变成了数字,排序呢,是按照数字的大小往下排的. 想自己给它们重新起名字,但是又不打乱音频的顺序.好吧,那就自己写写代码吧. 思路就是遍历音频文件的数字文 ...
- Vue.js简单的应用
1:一个简单实现 下面代码部分: <body> <div id="myDiv1"> {{userName}} </div> </body& ...
- Centos7.0 安装 oracle 11g 以及相关问题解决
参考其他的资源和自己实践内容总结出来的流程
- 03.redis与ssm整合(mybatis二级缓存)
SSM+redis整合 ssm框架之前已经搭建过了,这里不再做代码复制工作. 这里主要是利用redis去做mybatis的二级缓存,mybaits映射文件中所有的select都会刷新已有缓存,如果不存 ...
- yii框架开启事务
public function actionAdd() { $model = new Goods(); $model->setScenario('insert'); if ($model-> ...
- Golang 探索对Goroutine的控制方法
前言 在golang中,只需要在函数调用前加上关键字go即可创建一个并发任务单元,而这个新建的任务会被放入队列中,等待调度器安排.相比系统的MB级别线程栈,goroutine的自定义栈只有2KB,这使 ...