随着中国企业出海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审核的更多相关文章

  1. 在 Windows Azure 上部署预配置 Oracle VM

    Microsoft 和 Oracle 近期宣布建立战略合作伙伴关系,基于此,我们将通过 Windows Azure 镜像库推出多种常用的 Oracle 软件配置.即日起,客户可以在 Windows S ...

  2. Azure上部署FTP服务

    FTP是个比较复杂的协议,其协议分为控制层和数据层,工作模式分为主动和被动两种模式. 在默认的Active模式下其工作原理如下: 可以看到,客户端发起FTP的请求道服务器端,FTP的端口是21.用户在 ...

  3. Azure上部署Barracuda WAF集群 --- 2

    前面一篇文章讲了如何在Azure上部署Barracuda.这篇文章聊一聊如何配置Barracuda. License 向Barracuda的销售人员申请WAF的License.得到License后打开 ...

  4. 不可或缺 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 ...

  5. 在 Azure 上部署 Asp.NET Core Web App

    在云计算大行其道的时代,当你要部署一个网站时第一选择肯定是各式各样的云端服务.那么究竟使用什么样的云端服务才能够以最快捷的方式部署一个 ASP.NET Core的网站呢?Azure 的 Web App ...

  6. [文章存档]Azure上部署的java app在向第三方服务传送中文时出现乱码

    https://docs.azure.cn/zh-cn/articles/azure-operations-guide/app-service-web/aog-app-service-web-java ...

  7. 【翻译】使用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 ...

  8. 在公有云AZURE上部署私有云AZUREPACK以及WEBSITE CLOUD(一)

    (一)前言 本文主要介绍了实践部署AzurePack的Website Cloud的过程.在部署之前, 首先要对AzurePack有个基本的了解.   Azure Pack是微软的私有云方案,具有弹性. ...

  9. 在 Windows Azure 上部署并定制化 FreeBSD 虚拟机镜像

     发布于 2014-12-11 作者 陈阳 FreeBSD 基础镜像现已登陆中国的 VM Depot! 对于青睐 BSD 而非 Linux 的开源爱好者来说,这无疑是个好消息.同时,随着该基础镜像 ...

随机推荐

  1. Spring集成Quartz完成定时任务

    在JavaEE系统中,我们经常会用到定时任务,比如每天晚上凌晨之后跑批处理或者是每天某个时刻群发消息等等. 我们可以使用java.util.Timer结合java.util.TimerTask来去完成 ...

  2. openSUSE 13.1 搭建 DNS服务器

    1. Setup Primary DNS Server Install bind9 BIND (Berkely Internet Name Domain) is a software for tran ...

  3. linux服务器使用yum安装nginx

    一,安装nginx和php-fpm yum install nginx php-fpm 二, 找到nginx.conf find / -name nginx.conf 三,添加解析php配置 在ser ...

  4. Python 爬虫练习(一) 爬取国内代理ip

    简单的正则表达式练习,爬取代理 ip. 仅爬取前三页,用正则匹配过滤出 ip 地址和 端口,分别作为key.value 存入 validip 字典. 如果要确定代理 ip 是否真的可用,还需要再对代理 ...

  5. React+Redux实现追书神器网页版

    引言 由于现在做的react-native项目没有使用到redux等框架,写了一段时间想深入学习react,有个想法想做个demo练手下,那时候其实还没想好要做哪一个类型的,也看了些动漫的,小说阅读, ...

  6. python/numpy/tensorflow中,对矩阵行列操作,下标是怎么回事儿?

    Python中的list/tuple,numpy中的ndarrray与tensorflow中的tensor. 用python中list/tuple理解,仅仅是从内存角度理解一个序列数据,而非数学中标量 ...

  7. SpringCloud学习笔记(3)——Hystrix

    参考Spring Cloud官方文档第13.14.15章 13. Circuit Breaker: Hystrix Clients Netflix提供了一个叫Hystrix的类库,它实现了断路器模式. ...

  8. 51Nod 1293 球与切换器 DP分类

    基准时间限制:1 秒 空间限制:131072 KB   有N行M列的正方形盒子.每个盒子有三种状态0, -1, +1.球从盒子上边或左边进入盒子,从下边或右边离开盒子.规则: 如果盒子的模式是-1,则 ...

  9. PAT 1008. Elevator (20)

    1008. Elevator (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue The highest ...

  10. php命令执行脚本

    php -f jiaoben.php &  读入并解释指明的文件.