hy这个破项目
最近部署hy记事
这段时间摊上了个挺恶心的项目,叫什么hy鞋同平台。。前后左右整的人挺难受的。学到的东西特别少,而且比较浪费时间。不过,还是总结一下吧,好歹花了这么久的时间了
Doc管理xi tong
话说这个hy平台的起因,罪魁祸首就是6月份开始调研的wen dang管理系统。只从技术角度说说吧。
wendang管理系统调研:
- Sea-(f!)ile 国产的,广告做的挺响亮,下一代wendang管理软件.
- Open-(K!)m 国外的开源软件,Java写的,功能挺全面,但是就是很复杂
- 调研情况:后者使用到了很多的Java组件,各种各样的什么都有。对于我Java盲而言确实比较费劲。但第一次接触到了Java的强大,而且理解为什么企业系统是Java在一统天下(如果有一天能有机会接触Java项目,我肯定第一个上)。
-- tomcat服务器:企业级的应用服务器,保证了稳定性和效率
-- hibernate数据库驱动:任意连接所有数据库,强大到无法自拔
-- elasticsearch及其基于的lu什么搜索引擎:搜索就靠它了,无缝集成毫无问题
-- 还有Spring框架什么的,这个我一点不懂- 开源选型最后定为了前者,尽管后者功能强大,但是据说主体开发团队不喜欢Java,于是乎,python和C胜出了。从此开启了痛苦的开发历程。
audit 审计
我这块负责审计功能的开发,就是把用户在系统上的操作都记录下来。这儿最初的思想十分简单,就是找到源码中相应的执行操作的点,把审计函数插入进去就行了,传入一些相关的参数即可。也是第一次接触django,刚开始手足无措,后来才知道有url.py文件,才慢慢从前端js跟踪到了后端的python函数,将审计函数插入其中。刚开始做的时候想起了linux系统自带的审计,记得它也是将某个审计函数插入在所需的地方,然后通过一些配置文件能够对审计的开启、关闭,审计信息的详细程度进行配置。我们这里就不用这么复杂了。。写了个简单的审计函数,先将数据丢进es去了。之后有了其他组做好了mysql Rest API,就把es换成他们得api了。其实都是一样的:写了个函数,调用python的curl模块,继而调用Rest API。后来发现有时curl速度比较慢,影响到了用户的页面体验。然后就调研django异步执行框架celery,将curl函数一包装,放进celery的worker里执行,这样就不影响页面响应速度了。不过,这里还没有做的地方是审计函数的执行结果没有进行判断(成功or失败?)。其实想了一个方案,把结果丢进redis里,随后找个午夜时间(定时执行也靠celery框架)用相关函数处理一下(但后来没实现这方案)。
部署django项目
哎呀,这块刚开始时候可是被整的。。系统依赖的软件包、python模块相当的多,而且没有提供自动部署脚本,导致大量时间浪费在了部署上面。不过,也正因为此,才导致我遇见了docker这货。当时由于部署复杂,开发组专门提供了一个虚拟机镜像,里面预装好了所有依赖包。但是该镜像居然有8.0G大小,携带、传输都十分困难(百度网盘也不支持这么大的。。。),导致没有什么卵用。然后就想起了过年来的时候调研过docker,它不就是做依赖包封装、持续集成用的吗?很兴奋的用起docker来,果不其然,特别方便,镜像做出来也特别小(很少超过1G)。更好的地方是部署、迁移、更新、启动、关闭速度都远远优于笨拙的虚拟机。接着,我将本机的所有服务都搞成docker容器了。。。(当时热衷于此,觉得是赶时髦了),然后还搞了mesos+zookeeper+marathon来管理本机的这5、6个容器。真是不亦乐乎。要说docker有什么缺点,那就是无法跑在win系列机器上(但是听说win也支持docker了),其他方面都是优点,用起来大大的爽,部署时间从2-3天减少到2-3个小时。
随着docker使用的频繁,也想试试持续集成是什么鬼。于是自己鼓捣出一个方式。由于在本机之前搭建过一套gitlab服务器,就想着怎么能把他们联系起来。我写好代码之后,push到gitlab上,然后利用git的hooks方式,判断本次commit的代码注释(-m)是否带有[deploy]字样的,如果有,就进入一个特定目录执行pull操作。该特定目录是mount在docker容器内的。还是在hooks这个脚本中,执行docker exec命令,进而在容器内部执行部署脚本(部署脚本也是在commit的源码中)。然后就大功告成了,容器中会对源码进行编译、安装、服务启动。也就是说,开发完后直接执行push,然后就等着刷新浏览器吧!自以为体验到了持续集成的一点小优势~(但是整个过程的最后一步docker exec没有实现,当时好像是因为docker版本太低,还不支持exec命令。当时都是人工进容器,然后执行部署脚本的。。。)
此事后记:从此对docker感兴趣,最近又自己看了看go语言的书 。。。想着啥时候能看看docker的源码呢!
被逼使用Openstack
不知是为了实际作用还是说为了能让项目花哨点儿、有料点儿,后来提出了让各个服务部署在Openstack虚拟机上,列出了一堆堆Openstack的优势。
但是当时的形势是我在自己机器上已经通过docker基本构建起了hy平台的各项服务,又因为对新东西Openstack不熟,所以情绪还是蛮抵制的。不过也是久闻大名了,也看到很多帖子写到为什么docker能替代Openstack的争论,后来还是老老实实开始了Openstack的调研(其实主要是领导热衷于这个。。 我当然不得不去做了)。
但是,此处应该记住教训,不要对新东西犹豫不决,不去用过,是没有发言权的。
云计算这么火,Openstack作为云平台的管理软件,起着核心的作用。我们的hy平台运行的服务大概有5、6种,初步思想是把每种服务都单独运行在一台实例上。于是乎开始调研,然后尝试安装K版;在安装基本完成时,官网又发布了L版。。
下面总结这个过程中的关键点。首先是部署结构的设计。devstack使用单机部署所有服务,但官网的手动部署教程是使用控制、网络、计算三节点的部署方式。我使用后者在virtualbox上搞了一套L版。然后,最重要的就是网络配置部分,这里要首先理解原理然后再进行部署才行。在这块刚开始弄的时候,一头雾水,搞了3、4天没有头绪,因为想赶紧把环境搞起来,但是根本不了解原理,瞎打瞎撞。这些相关资料网上都有,而且这里的思想就是SDN,学习一下这些技术还是很令人兴奋。最后,还有一个关键点是备份。我们部署中间有一次断电了,然后重启后各种都起不来。。 这时所需的应该是将虚拟机镜像进行断电前备份、断电后导入;导入包括从控制节点1导入控制节点2、从控制节点导入宿主机kvm,其实方法都是一样,就是把实例的虚拟磁盘搞出来就好,这块要理解kvm虚拟磁盘的格式、backing file、打快照的方法等。
被文档折磨的死去活来
需求文档写了将近一个月,紧接着开始写设计文档。实际上我们的系统基本已经成型(反正是基于开源的搞的),但是上面要求用写文档的形式理顺目前做的事。
写文档过程中的经验教训。首先,心态要好。做程序猿虽说应该以代码为重,但是文档任务也不能掉以轻心。能叙述的清楚的程序猿,编码起来才能行云流水。文档中的文字描述、流程图之类的能很好的帮助思路。不要抵制,既然是工作,就不是自己想怎样就怎样的;任务分下来了,那就认真对待,好好做。不要区分任务的等级高低、类型贵贱(不要分脏活累活还是好活),不管啥活,用心认真做了,学到的东西就是自己的。然后,网上粘贴的东西要仔细过两遍,不能为了堆砌篇幅而瞎贴。其实还是回到之前说的,不要用应付的心态去做这件事。
是挺难受的,我承认。需求文档、设计文档写了好几稿,都被打回来。还是那句话,对于有些任务,真的心态要好。
补充内容
这次项目让知识面拓宽了不少。一直在思考是要广还是要精的问题,在目前的工作环境下,做的活杂七杂八,接触东西很多,在广上有优势。但我还是想确定好自己的方向,比如云计算,比如虚拟化。兴趣我是有的,但这得自己努力了。听说要做开发者很难的,每天下班、周末都应该去学习、看代码的。自己还是差太远了。
hy这个破项目的更多相关文章
- Rabbitmq消息服务器通讯异常: name must not be blank
前人挖坑,后人填! 倒霉的遇到一个破项目,该 项目使用了 RabbitMQ 消息队列向服务器发送消息, 但在发送中老是报 RabbitMQ 服务器异常! 呃,查看了服务器,服务器好好的,日志中却是这样 ...
- 番茄日志发布1.0.3版本-增加Kafka支持
番茄日志(TomatoLog)能做什么 可能你是第一次听说TomatoLog,没关系,我可以从头告诉你,通过了解番茄日志,希望能帮助有需要的朋友,番茄日志处理将大大降低你采集.分析.处理日志的过程. ...
- 发现最新版百度Android 定位SDK v6.1.3 网络定位bug
对于百度地图已经实在忍无可忍了,实验室两年以前的一个项目用到了百度地图,以前师兄毕业了,我来维护这个破项目,百度地图推出新版本出来后,老版本的api不能用了,不能做到向下兼容吗?换掉少量的api也就算 ...
- Java线程池初步解读
好好学习,天天向上 本文已收录至我的Github仓库DayDayUP:github.com/RobodLee/DayDayUP,欢迎Star 几个月前,写了一篇<Java并发学习(一):进程和线 ...
- [IIS]发布到 IIS 上的程序没有权限访问共享文件
老板突然跑路了,丢下一个破项目让我一个人维护,各种奇葩问题不断. 为了弄一键发布,布置了新的环境,结果新环境下的程序不能访问共享文件了. 访问共享文件需要设置应用程序池(Application Poo ...
- 《ASP.NET MVC 5 破境之道》:第一境 ASP.Net MVC5项目初探 — 第三节:View层简单改造
第一境 ASP.Net MVC5项目初探 — 第三节:View层简单改造 MVC默认模板的视觉设计从MVC1到MVC3都没有改变,比较陈旧了:在MVC4中做了升级,好看些,在不同的分辨率下,也能工作得 ...
- 12306 抢票项目霸榜 GitHub,标星即将破万
十一将至,你买到回家的火车票了吗?如果没有,你可以试着打开 GitHub,在搜索栏键入 12306 的关键词,我相信你会发现一个新大陆.没错,这里有 1572 个抢票项目.它们大多用 Python.J ...
- 一个基于 Vue3 的开源项目,3个月时间 star 终于破千!
本文主要是对如何做开源项目的一些思考. 前文回顾: <Vue3 来了,Vue3 开源商城项目重构计划正式启动!> <一个基于 Vue 3 + Vant 3 的开源商城项目> 关 ...
- 《ASP.NET MVC 5 破境之道》:第一境 ASP.Net MVC5项目初探 — 第二节:MVC5项目结构
第一境 ASP.Net MVC5项目初探 — 第二节:MVC5项目结构 接下来,我们来看看,VS为我们自动创建的项目,是什么样子的? 可以通过菜单中[View]->[Solution Explo ...
随机推荐
- python爬虫得到unicode编码处理方式
在用python做爬虫的时候经常会与到结果中包含unicode编码,需要将结果转化为中文,处理方式如下 str.encode('utf-8').decode('unicode_escape')
- HDOJ 6508 Problem I. Spell Boost (01背包/DP)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=6508 题目: Problem Description Shadowverse is a funny car ...
- L2-006 树的遍历 (25 分)
链接:https://pintia.cn/problem-sets/994805046380707840/problems/994805069361299456 题目: 给定一棵二叉树的后序遍历和中序 ...
- eclpse:安装explorer或eExplorer插件
结论:个人感觉 eExplorer更好. 1.安装explorer Help->Eclipse Marketpalce find:explorer dian 点击"Install&qu ...
- GrayLog + Logspout + Docker 实现分布式日志聚合
前提条件:你的服务器上已经安装了Docker和Docker Compose 一.安装GrayLog(Docker方式) version: '2' services: mongodb: image: m ...
- 发送邮件工具类MailHelper
using System; using System.Net; using System.Net.Mail; using System.Text; using System.Threading; na ...
- Python Django-入门到进阶
web应用 Python-web应用 +HTTP协议 +web框架 第二篇:Djangon简介 Diango 框架起步 Python-Django基础 第三篇:路由控制 Python-Django 路 ...
- cadcam
Email:kefu007@vip.qq.com 13D TIMON 2007 英語版2007 23DVIA Composer V6R2013 中文版2013 3ABQUS V6.11 6.11 4A ...
- 末学者笔记——SAMBA服务、FTP服务讲解
samba服务 一.概念: Smb主要作为网络通信协议; Smb是基于cs(client,sever)架构: 完成Linux与windows之间的共享:linux与linux之间共享用NFS 二. ...
- disconf使用小结
disconf使用小结 目前我们公司用的分布式配置中心是disconf,对于普通的spring项目集成还是比较方便,主要功能点分布式配置还有配置的动态更新通知 安装disconf服务端 参考地址htt ...