本文共 4706 字,大约阅读时间需要 15 分钟。
发布一个页面,需发布到该页面所属的每个站点服务器,其它站点服务器不发布
比如:发布一个门户的页面,需要发布到每个门户服务器上,而用户中心服务器则不需要发布 所以本项目采用routing模式,用站点id作为routingKey,这样就可以匹配页面只发布到所属的站点服务器上 页面发布流程:1、前端请求cms执行页面发布
2、cms执行静态化程序生成html文件 3、cms将html文件存储到GridFS中 4、cms向MQ发送页面发布消息 5、MQ将页面发布消息通知给Cms Client 6、Cms Client从GridFS中下载html文件 7、Cms Client将html保存到所在服务器指定目录
创建Cms Client工程作为页面发布消费方,将Cms Client部署在多个服务器上,它负责接收到页面发布的消息后从GridFS中下载文件在本地保存
页面发布消费方:
需求:1、将cms Client部署在服务器,配置队列名称和站点ID
2、cms Client连接RabbitMQ并监听各自的“页面发布队列” 3、cms Client接收页面发布队列的消息 4、根据消息中的页面id从mongodb数据库下载页面到本地
调用dao查询页面信息,获取到页面的物理路径,调用dao查询站点信息,得到站点的物理路径
页面物理路径=站点物理路径+页面物理路径+页面名称 从GridFS查询静态文件内容,将静态文件内容保存到页面物理路径下创建Cms Client工程:
1、pom中添加amqp、mongodb、io、fastjson依赖 2、yml文件中配置MongoDB、rabbitmq服务 3、编写RabbitmqConfig配置类 创建交换机 每个队列与交换机绑定 配置队列名称和routingKey,将站点ID作为routingKey 最重要还是这个配置类定义消息格式:消息内容采用json格式存储数据
PageService: 保存html页面到服务器物理路径: 根据pageId查询cmsPage表获取:FileId、SiteId、PageName、PagePhysicalPath; 拼接页面的物理路径; 将页面的物理路径保存到服务器物理路径上;ConsumerPostPage:
作为发布页面的消费客户端,监听 页面发布队列的消息,收到消息后从mongodb下载文件,保存在本地。页面发布生产方:
CMS系统作为页面发布的生产方,管理员通过 cms系统发布“页面发布”的消费。 1、yml中配置Rabbitmq的连接参数 2、pom中配置amqp 3、RabbitMQConfig配置 由于cms作为页面发布方要面对很多不同站点的服务器,面对很多页面发布队列,所以这里不再配置队列,只需要 配置交换机即可。 4、在PageService类中定义页面发布方法postPage、发送页面发布消息sendPostPage、保存静态页面内容saveHtml。代码执行流程:
在page_list.vue
页面 发布
点击发布调用postPage方法:
postPage: function (pageId) { this.$confirm('确认发布该页面吗?', '提示', { }).then(() => { cmsApi.page_postPage(pageId).then((res) => { if (res.success) { console.log('发布页面id=' + pageId); this.$message.success('发布成功,请稍后查看结果'); } else { this.$message.error('发布失败'); } }); }).catch(() => { }); }
调用page_postPage请求后端接口:
/*发布页面*/export const page_postPage= id => { return http.requestPost(apiUrl+'/cms/page/postPage/'+id)}
执行CmsPageController中方法:
rabbitTemplate.convertAndSend
方法发送消息: 用户的操作流程:
1、进入我的课程
2、点击“添加课程”,进入添加课程界面 3、输入课程基本信息,点击提交 4、课程基本信息提交成功,自动进入“管理课程”界面,点击“管理课程”也可以进入“管理课程”界面 5、编辑图片 上传课程图片 6、编辑课程营销信息 营销信息主要是设置课程的收费方式及价格 7、编辑课程计划 添加课程计划
课程计划:定义了课程的章节内容, 课程计划包括两级,第一级是课程的大章节、第二级是大章节下属的小章节,每个小章节通常是一段视频,学生点击小章节在线学习
代码实现: 前端使用element-ui 的tree组件来完成,在course_plan.vue文件中添加tree组件的代码数据对象:
data() { return { mediaFormVisible:false, teachplayFormVisible:false,//控制添加窗口是否显示 teachplanList : [{ id: 1, pname: '一级 1', children: [{ id: 4, pname: '二级 1-1', children: [{ id: 9, pname: '三级 1-1-1' }, { id: 10, pname: '三级 1-1-2' }] }] }], defaultProps:{ children: 'children', label: 'pname' }, teachplanRules: { pname: [ { required: true, message: '请输入课程计划名称', trigger: 'blur'} ], status: [ { required: true, message: '请选择状态', trigger: 'blur'} ] }, teachplanActive:{ }, teachplanId:'' } }
后端采用表的自连接方式进行查询,mapper.xml文件的SQL语句如下:
说明:针对输入参数为简单类型#{}中可以是任意类型,判断参数是否为空要用 _parameter(它属于mybatis的内 置参数)
添加课程计划:
上级结点说明: 不选择上级结点表示当前课程计划为该课程的一级结点。 当添加该课程在课程计划中还没有节点时要自动添加课程的根结点 添加课程计划采用弹出窗口组件Dialog 1、在course_plan.vue页面添加添加课程计划的弹出窗口代码:视频 文档 未发布 已发布 提交 重置
2、在数据模型中添加如下变量:
teachplayFormVisible:false,//控制添加窗口是否显示
3、后台CourseController中编写addTeachplan方法
测试流程: 1、新建一个课程 2、向新建课程中添加课程计划 添加一级结点 添加二级结点转载地址:http://trie.baihongyu.com/