网站发布小工具,--让发布变简单一点

网站发布工具

灵感来源:每次发布都需要登录远程服务器,备份旧文件上传新文件,在不同文件夹之间反复切换非常繁琐,程序员可都是懒人,那能每天时间都耗在这些繁琐的事情上,而且还需要非常小心避免出错。最开始是用Python做了一个小工具,直接在文件上点击右键即可上传到服务器右键上传。单个文件上传倒是非常快捷,但是对于‘上传多个文件,上传文件夹’类似于zip软件右键压缩类型的功能,网上查询了一些资料,但是没有找到适合我的技术方案。最后决定牺牲一点快捷性,放弃右键方案,使用winform做客户端,使用Node.js做服务器,开发这个小工具。

服务器端介绍

部署

  • 安装Node.js
  • 下载DepolyServer 并解压
  • 进入DeployServer目录,shift+鼠标左键,选择“在此处打开命令窗口”输入node index 80 启动server。端口号可省略,默认值3000

启动成功后界面会提示 The depolyServer is now ready to accept connections on port 80

在启动前需要完善配置文件config.js

module.exports = {
  projects:[{
    "name":"admin",                            //项目名称 不建议中文,用于创建文件夹,遵守文件夹命名约定。
    "directory":"d:\wwwroot\web\",          //IIS网站根目录
    "users":[{"account":"ywb","password":"123"},{"account":"帐号","password":"密码"}],
    "fileHandlers":[
      {filePath:'\web.config',rules:[{name:'C',p1:'test string'},{name:'B',p1:'test string',p2:'new string'},{name:'B',p1:/x/g,p2:'y'}]}
    ]
  }]
}
// fileHandlers.filePath 设置需要处理的文件,相对路径,需要以  开头
// 示例fileHandlers规则意思是:在文件'web.config'的尾部增加字符串'test string',然后将文件中的字符串'test string' 改为'new string'。
// 适用场景 增加js代码,用于在测试环境增加一些提示文本,用户在正式环境增加统计代码,或者替换一些关键配置。

//rule规则说明 
var rules = [
  {
    name:'A',//用 p1文件 覆盖上传的文件
    p1:'\my\web.config'  // 相对于DeployServer运行目录
  },
  {
    name:'B',//对上传的文件进行字符串替换 相当于str.replace(p1, p2)  
    p1:'old text | regexp ',
    p2:'new text | regexp '
  },
  {
    name:'C',//将字符串追加到上传文件尾部
    p1:'append string'
  }
]

上传文件存放目录约定

data 目录,存放所有上传文件的历史数据。
data{project} 目录,存放某个'project'上传文件的历史数据
data{project}history 目录,存放文件历史数据。
data{project}{yyyymmdd}-{tag}.json 日志文件,每次上传日志文件。 未解决:如果在23:59分进行文件上传,上传文件较多,会产生回滚BUG
日志文件内容约定

{
  data: '2016-12-14 11:09:00',                           //文件上传时间
  tag: '{tag}',                                          //标签  (上传时可以自由约定标签,使用有意义的字母,遵守文件命名规则)
  account: 'ywb',                                        //上传人
  memo: '修改短信接口',                                   //上传原因
  target: '\web.config',                                //目标文件相对路径
  old: "\data\{project}\history\20161214\{tag}-Web-old-34c123a0.config",  //旧文件备份  如果为空,说话没有找到旧文件
  new: "\data\{project}\history\20161214\{tag}-Web-new-34c123a0.config"   //新上传的文件备份  因为同一个Tag,同一个文件可能反复推送,所以增加了一个随机标识,记录每一次推送内容
}

回滚操作 命令行工具

请避免project名称中间有空格,不解决该BUG,哦
node back 列出所有project
node back -l admin 列出admin下的所有上传日志
node back -r admin tag 回滚admin下的tag日志 tag支持1,2,3,回滚序号对应的Tag。
输入图片说明

客户端介绍

安装

  • 基于.NET Framework 2.0 ,一般系统自带,没有则需要安装
  • 下载DepolyClient 并解压
  • 双击 DeployClient.exe

在启动前需要完善配置文件config.json

[
  {
    "Name": "Web 正式环境",                 //你容易理解的名称
    "Url": "http://localhost:3000/upload",  //替换localhost:3000成 server的 域名:端口号
    "Project": "admin",                     //与server配置保持一致
    "Account": "ywb",                       //帐号 与server配置保持一致
    "Password": "123",                      //密码 与server配置保持一致
    "Directories": "D:\publish\admin\;D:\postFile\postfile\", //本地目录 可配置多个 ;号分隔
    "Files": "dll;cshtml;js;json;config;css;png;html;jpg",          //允许上传的文件后缀 ;号分隔
    "IgnorePath": "\Assets;\Content\themes"                      //上传忽略的路径 ;号分隔
  },
  {
    "Name": "Admin 正式环境",
    "Url": "http://localhost:3000/upload",
    "Project": "admin22",
    "Account": "ywb22",
    "Password": "1234",
    "Directories": "D:\publish\Web",
    "Files": "dll;cshtml;js;json;config;css;png;html;jpg",
    "IgnorePath": "\Assets;\Content\themes"
  }
]

其它说明

  • 可单独为某人配置上传帐号,方便管理,避免需要知道服务器帐号密码才能发布
  • 上传文件有加密验证,不用担心数据被窃取
  • 源码:https://git.oschina.net/nxwsyang/deploy
原文地址:https://www.cnblogs.com/snryang/p/6183523.html