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

其它的想到再写吧。


推荐阅读
  • 本指南详细介绍了如何利用华为云对象存储服务构建视频点播(VoD)平台。通过结合开源技术如Ceph、WordPress、PHP和Nginx,用户可以高效地实现数据存储、内容管理和网站搭建。主要内容涵盖华为云对象存储系统的配置步骤、性能优化及安全设置,为开发者提供全面的技术支持。 ... [详细]
  • 本文详细介绍了如何解决DNS服务器配置转发无法解析的问题,包括编辑主配置文件和重启域名服务的具体步骤。 ... [详细]
  • 网站访问全流程解析
    本文详细介绍了从用户在浏览器中输入一个域名(如www.yy.com)到页面完全展示的整个过程,包括DNS解析、TCP连接、请求响应等多个步骤。 ... [详细]
  • 两个条件,组合控制#if($query_string~*modviewthread&t(&extra(.*)))?$)#{#set$itid$1;#rewrite^ ... [详细]
  • 解决Parallels Desktop错误15265的方法
    本文详细介绍了在使用Parallels Desktop时遇到错误15265的多种解决方案,包括检查网络连接、关闭代理服务器和修改主机文件等步骤。 ... [详细]
  • 解决 Windows Server 2016 网络连接问题
    本文详细介绍了如何解决 Windows Server 2016 在使用无线网络 (WLAN) 和有线网络 (以太网) 时遇到的连接问题。包括添加必要的功能和安装正确的驱动程序。 ... [详细]
  • 为了提升单位内部沟通效率,我们开发了一套飞秋软件与OA系统的消息接口服务系统。该系统能够将OA系统中的审批、通知等信息自动同步至飞秋平台,确保员工在使用飞秋进行日常沟通的同时,也能及时获取OA系统的各类重要信息,从而实现无缝对接,提高工作效率。 ... [详细]
  • 自动验证时页面显示问题的解决方法
    在使用自动验证功能时,页面未能正确显示错误信息。通过使用 `dump($info->getError())` 可以帮助诊断和解决问题。 ... [详细]
  • Python 数据可视化实战指南
    本文详细介绍如何使用 Python 进行数据可视化,涵盖从环境搭建到具体实例的全过程。 ... [详细]
  • 数字资产量化交易通过大数据分析,以客观的方式制定交易决策,有效减少人为的主观判断和情绪影响。本文介绍了几种常见的数字资产量化交易策略,包括搬砖套利和趋势交易,并探讨了量化交易软件的开发前景。 ... [详细]
  • 自定义滚动条美化页面内容
    当页面内容超出显示范围时,为了提升用户体验和页面美观,通常会添加滚动条。如果默认的浏览器滚动条无法满足设计需求,我们可以自定义一个符合要求的滚动条。本文将详细介绍自定义滚动条的实现过程。 ... [详细]
  • 微软推出Windows Terminal Preview v0.10
    微软近期发布了Windows Terminal Preview v0.10,用户可以在微软商店或GitHub上获取这一更新。该版本在2月份发布的v0.9基础上,新增了鼠标输入和复制Pane等功能。 ... [详细]
  • 深入解析Struts、Spring与Hibernate三大框架的面试要点与技巧 ... [详细]
  • 虚函数表指针vptr的功能测试与分析
    类的虚函数调用依赖于虚函数表来实现。虚函数表是由编译器自动生成的一段内存区域,用于存储包含虚函数的类中每个虚函数的入口地址。这些入口地址本质上是指针类型,从而使得动态绑定成为可能。本文对虚函数表指针(vptr)的功能进行了详细的测试与分析,探讨了其在多态性和继承机制中的作用及其性能影响。 ... [详细]
  • 该大学网站采用PHP和MySQL技术,在校内可免费访问某些外部收费资料数据库。为了方便学生校外访问,建议通过学校账号登录实现免费访问。具体方案可包括利用学校服务器作为代理,结合身份验证机制,确保合法用户在校外也能享受免费资源。 ... [详细]
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社区 版权所有