【G】开源的分布式部署解决方案文档 - Web Deploy

G.系列导航

【G】开源的分布式部署解决方案 - 导航

微软官方部署方式

右键项目->发布

这个大家应该再熟悉不过,在部署前有个预览界面可以看本次更新到底更新哪些文件。

既然它可以预览部署结果,那其实它部署也不会完全覆盖,而是采取部分覆盖的方式,并提供了增、删、改的实际数量。

这都要依赖一个叫做 Web Deploy 的项目。 传送门

当然,web deploy功能绝不仅仅如此,包括打包、备份、还原、更新数据库等。

在此不多做普及,提到了它的优点,自然要支持它。所以本项目支持原始+Web Deploy两种部署方式。

Web Deploy部署方式

不推荐用IIS的Web 平台安装程序来下载Web Deploy,我们使用的Web Deploy 3.6版本,结果运行的时候是乱码状态。

建议官网自己下载英文版,完整安装。

项目编辑界面的部署流程中的第七个部署流程,选择部署方式为Web Deploy。并填写宿主属性Json。格式可以点击宿主属性前面的问号。

注意:因为我们配合Jenkins使用,所以zip包是自己压缩的。一定要从根目录压缩,不能包含上一层文件夹。否则Web Deploy比对时会删除网站下所有文件!!!

压缩命令格式:"C:\Program Files (x86)\7-Zip\7z.exe" a -r $deploy\WebsiteName.zip C:\ProjectInstance\WebsiteName\*

如你的网站目录为 C:\ProjectInstance\WebsiteName ,则你的压缩文件解压后应该是可以直接解压到 C:\ProjectInstance\WebsiteName,而不是 C:\ProjectInstance,这里跟本项目支持的原始部署方式是有本质区别!

namespace G.Infrastructure.Plugin.DeployHost.IIS.DeployModes
{
    public class WebDeployDeployWorker : IDeployWorker
    {
        public void Deploy(string deployFilePackagePath, string jsonHostProperty)
        {
            var webDeployHostProperty = JsonConvert.DeserializeObject<WebDeployHostProperty>(jsonHostProperty);
            List<Tuple<string, string, string>> lstCommand = new List<Tuple<string, string, string>>();

            lstCommand.Add(new Tuple<string, string, string>(
                @"C:\Program Files\IIS\Microsoft Web Deploy V3\msdeploy.exe",
                $@"-verb:sync -source:package=""{deployFilePackagePath}"" -dest:contentpath=""{webDeployHostProperty.WebsiteName}""",
                "总更改数"));

            lstCommand.ForEach(command =>
            {
                ProcessHelper.Run(command.Item1, command.Item2, command.Item3);
            });
        }
    }
}

Web Deploy部署调用的 msdeploy.exe,并通过package命令操作zip发布到网站名称相同的内容路径。

原始部署方式

 此方式已不推荐使用,原理就是解压覆盖目录,并修改web.config文件触发最后修改,保证网站以最新状态启动。

 

升级版本

目前最新版本为0.0.0.2(Beta),升级执行脚本 G\SQLScripts\0.0.0.2(Beta).sql

posted @ 2017-04-06 18:36  寻找和谐  阅读(1388)  评论(2编辑  收藏  举报