热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

整理近期工作的一些收获,做备忘

1、Redis的简单应用及搭建,未做深入学习,简单,目前的情况大概当做跨服务器Session使用,由于项目的原因,未能在项目在大规模应用,涉及到旧项目改造的成本和代码太高。2、MQ

1、Redis的简单应用及搭建,未做深入学习,简单,目前的情况大概当做跨服务器Session使用,由于项目的原因,未能在项目在大规模应用,涉及到旧项目改造的成本和代码太高。

2、MQTT,基于MQTT的消息订阅和发布机制,是很有意思的一个思路,也在项目中实践应用;

3、Nginx,有个需求,需要同一台服务器的webSocket和https使用同一个端口,使用HaProxy死活做不了,使用TCP四层协议的时候,无法向后端透传客户的真实IP地址,使用HTTPS无法自动识别,后来使用NGINX的HTTPS机制,完美实现。

4、重新改造的预发布文件系统监控、SQL脚本批量多服务器执行、负载均衡多服务器代码一键发布;在这半年的时间里,反复验证,已经基本完美,无缺陷、无BUG,保持长时间稳定运行;

5、更进一步认识LINQ、EF框架;有更深刻的了解;

6、对SQL、存储过程写法,应用得比过去更多,场景更变态,更复杂,对自已也算是对不足的一个补充;

7、见识了不同人所写的代码、对系统的设计思路,有优有劣;

8、最近半年,由于现网系统的架构原因,主要基于存储过程编写,同时有很复杂庞大的业务系统,半年时间大约对系统了解也就在50%左右;但是这半年时,经常面对已经经过无数次优化的存储过程、查询和代码,总结了一些优化心得,略做描述,备忘

    A:SQL SERVER的跟踪管理器,用于查找reads读的次数超多(通常是未走索引,通过消息里的表扫描可以看出来)、或者du执行时间超过X秒的存储过程,找出来使用SQL查询分析器做分析,寻找和补充索引。

    B:新增索引优先考虑对现有索引的优化,考虑能与现有索引兼容的情况;

    C:多列索引的场景下,索引前后顺序决定查询条件是否走某个索引,索引列的升序降序,虽然不能体现减少reads或者扫描次数,但确确实实有时候能非常明显的提升查询速度;

    D:把不合理的查询方法改正,例如存储过程里相同、消耗时间的结果,多次重复查询;减少为1次;

    E:代码里不合理的循环的使用,以某个案例,查询1号到30号的数据,在循环内30次调用存储过程;执行接近60秒;改成直接查询范围1-30号,一次查询拿到全部目标结果,然后在程序代码里再对数据进行加工,分组,耗时降为5秒。

    F:SQL里以前很少用到的:Select * Into #temp from ...;update table_1 set x=1 output Insert.ID Into #Temp;等;接下来会继续学习;

    G:以前项目里极少、很少用到多表联合查询的场景,和业务、表的设计有关系,现有系统基本上全是这种结构;确实联合查询减少查询次数,能有效明显降低查询耗时,只是业务设计太复杂了,基本架构也设计得不行;库分太多,常常涉及跨库,做跨库事务是个麻烦事。

9、开始学习使用redmine管理项目进度;希望让工作能更科学;面对不同的挑战,以及空降这个事情,外加现有系统和业务的复杂,希望能逐步理清,也能借用这个场景历练自已。面对不同的困境,不断思考解决困难的方法,多实践,多反思。

其它的后续再补充;

 

整理一点平时的想法,和希望有机会实践的东西:

1、希望自已做一套分布式网关,同时自带API文档、入参校验、签名校验,支持服务间调用、应用化调用、外部业务调用;支持对分布式后端服务代码、程序做自动负载热更新;优先考虑在.NET Core的基础之下进行开发网关系统;

2、整理和再学习微服务架构;

3、用好redis、用活MQTT;或者自已开发一套基于webSocket的发布、订阅系统;多数场景下,可以使用webSocket来替代TCP;

4、思考对现有系统的复杂框架,在许可的条件下,逐步改造成无限扩展的分布式系统的各种方案,相信也许会有机会,或者有合适的启发,能向这个方向去发展;主要是代码量,存储过程的数量,表的数量,以及过去表设计不合理,业务复杂化,但历史遗留问题,虽然很难解决,还是需要不断的想办法。

其它的想到再写吧。


推荐阅读
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • CentOS 7部署KVM虚拟化环境之一架构介绍
    本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
  • Redis底层数据结构之压缩列表的介绍及实现原理
    本文介绍了Redis底层数据结构之压缩列表的概念、实现原理以及使用场景。压缩列表是Redis为了节约内存而开发的一种顺序数据结构,由特殊编码的连续内存块组成。文章详细解释了压缩列表的构成和各个属性的含义,以及如何通过指针来计算表尾节点的地址。压缩列表适用于列表键和哈希键中只包含少量小整数值和短字符串的情况。通过使用压缩列表,可以有效减少内存占用,提升Redis的性能。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 关于我们EMQ是一家全球领先的开源物联网基础设施软件供应商,服务新产业周期的IoT&5G、边缘计算与云计算市场,交付全球领先的开源物联网消息服务器和流处理数据 ... [详细]
  • CentOS 6.5安装VMware Tools及共享文件夹显示问题解决方法
    本文介绍了在CentOS 6.5上安装VMware Tools及解决共享文件夹显示问题的方法。包括清空CD/DVD使用的ISO镜像文件、创建挂载目录、改变光驱设备的读写权限等步骤。最后给出了拷贝解压VMware Tools的操作。 ... [详细]
  • 本文介绍了django中视图函数的使用方法,包括如何接收Web请求并返回Web响应,以及如何处理GET请求和POST请求。同时还介绍了urls.py和views.py文件的配置方式。 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了软件测试知识点之数据库压力测试方法小结相关的知识,希望对你有一定的参考价值。 ... [详细]
author-avatar
寻找另一半哥哥_335
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有