首先本文只是对官方文档(中文,英文)的一个提炼,详细的安装说明还请仔细阅读官方文档。html
虽然Service Fabric的官方名称每每被加上Azure,可是实际上(估计不少人不知道)Service Fabric能够安装到本地数据中心或者任意公有云上,这不官方文档就有一章专门讲如何安装到AWS的内容。node
因此如今为了区分,通常把在Azure上提供的开箱即用的PaaS称之为Azure Service Fabric,而把本地安装的称之为Service Fabric Standalone。docker
同时,Service Fabric既可部署到Windows Server上,也能够部署到Linux上。可是本文书写的时候,Linux版本只能使用Azure的,官方尚未发布本地版本安装包(可是将来必定会有)。因此本文也是仅限于Windows集群的内容。json
在本地数据中心安装Service Fabric for Windows集群的时候,可能会受到以下限制的影响:windows
机器的准备,须要至少知足以下要求:浏览器
域环境和域帐号:安全
虽然能够在某台集群机器上来运行Service Fabric的安装包,可是我建议单独使用一台操做机。操做机的准备:服务器
Service Fabric for Windows的安装包分为两个部分:网络
先经过其余渠道下载这两个安装包,而后复制到内网环境。编辑器
在操做机上解压安装包的zip压缩包,好比解压到SFSetup文件夹。把运行包的cab压缩包也复制到SFSetup文件夹备用(不用解压)。
首先,准备集群配置文件。
根据不一样的安全配置和集群配置,安装包提供了多个配置文件模板,分别是:
总结起来,Service Fabric for Windows支持非安全、Windows帐号、组托管服务帐号、X509证书和Windows帐号+X509混合等5种安全模式。
我的建议选择Windows帐号模型,由于准备工做要简单一些,成功的机率也大一些。若是一直报莫名其妙的错误,那么使用非安全模式大几率能够成功。在网络安全比较严格且机器加入域的状况下,非安全模式也是能够接受的。
以依赖Windows帐号安全机制的多机器集群为例,复制一份ClusterConfig.Windows.MultiMachine.json文件,重命名为方便处理的名称,好比ThisClusterConfig.1.0.json。用诸如VSCode这样的编辑器打开这个json文件。编辑其中的nodes部分。主要是修改iPAddress为每台机器的机器名。ClusterIdentity填入机器组的名称sfnodes,Identity改成专用域帐号的名称sfadmin。nodeTypes根据状况就暂时用一个或者自定义多个。
示例以下:
对于非安全模式的集群,无非是去掉了security配置节而已。
接着,对配置文件进行测试。
在SFSetup文件夹上打开PowerShell,执行以下命令:
.\TestConfiguration.ps1 -ClusterConfigFilePath .\ThisClusterConfig.1.0.json
若是配置文件没有什么问题的话,会显示以下提示:
在内网环境下,IsCabValid应该会显示为False的,这个不用担忧。
最后,基于配置文件建立集群。
继续在PS中执行以下命令:
.\CreateServiceFabricCluster.ps1 -ClusterConfigFilePath .\ThisClusterConfig.1.0.json –FabricRuntimePackagePath .\MicrosoftAzureServiceFabric.6.3.162.9494.cab
如今祈祷它能一次运行成功,若是5台机器的话,应该能在5分钟内成功。
提示成功后,经过输入以下命令来尝试链接集群的管理端口来进行验证:
Connect-ServiceFabricCluster -ConnectionEndpoint SFNode-01.contoso.com:19000
或者用浏览器打开管理后台:http://SFNode-01.contoso.com:19080/Explorer/index.html
若是你须要用Service Fabric来编排Windows Container的话,须要预先在集群机器上安装Docker。
因为内网环境的限制,安装Docker也会稍显麻烦。根据Docker.com的官方文档:https://docs.docker.com/install/windows/docker-ee/#use-a-script-to-install-docker-ee
能够经过命令启用Windows的容器支持:
(Install-WindowsFeature Containers).RestartNeeded
再下载docker的离线包到内网环境后按照步骤进行安装。
同时为了支持集群机器可以正常的获取Docker镜像,能够在内网环境运行一个Docker Registry做为私有镜像仓库供内部应用镜像的存放处,在外网运行一个Docker Registry做为公共镜像的Mirror,供私有仓库和集群机器使用。