应用服务器优化技术

分布式缓存

缓存的本质就是内存中的哈希表 主要用来存放那些读写比很高、变化很少的数据,这样应用程序读取数据时先到缓存中读取,如果没有或者数据已经失效再去访问数据库或文件系统,并根据拟定的规则将数据写入缓存。
特点: 分布式缓存能够高性能地读取数据、能够动态地扩展缓存节点、能够自动发现和切换故障节点、能够自动均衡数据分区,而且能够为使用者提供图形化的管理界面,部署和维护都十分方便。

JBoss Cache

这里写图片描述

Memchached

这里写图片描述

消息队列

消息队列服务器,是位于应用服务器和数据库服务器之间的一个服务器。消息队列服务器作为一个缓冲,接收应用服务器发送过来的数据库操作命令,然后按照自己的配置,依次发送给数据库服务器来执行。这种数据库执行的方式,我们称之为异步写入数据库。
特点:由于消息队列服务器的速度远远高于数据库服务器,所以能够快递处理并返回数据。消息队列服务器具有更好的扩展性。在高并发的情况下,延迟写入数据库,可以有效降低数据库的压力。

这里写图片描述

这里写图片描述

RabbitMQ

.NET 环境中使用RabbitMQ

Redis

使用Redis作为消息队列服务场景应用案例
redis做消息队列

使用集群

在网站高并发访问的场景下,使用负载均衡技术为一个应用构建一个由多台服务器组成的服务器集群,将并发访问请求分发到多台服务器上处理,避免单一服务器因负载压力过大而响应缓慢,使用户请求具有更好的响应延迟特性。
这里写图片描述

代码优化

多线程

多线程就是指一个进程中同时有多个执行路径(线程)正在执行

优点
1. 在一个程序中,有很多的操作是非常耗时的,如数据库读写操作,IO操作等,如果使用单线程,那么程序就必须等待这些操作执行完成之后才能执行其他操作。使用多线程,可以在将耗时任务放在后台继续执行的同时,同时执行其他操作。
2. 可以提高程序的效率。
3. 在一些等待的任务上,如用户输入,文件读取等,多线程就非常有用了。
缺点
1. 使用太多线程,是很耗系统资源,因为线程需要开辟内存。更多线程需要更多内存。
2. 影响系统性能,因为操作系统需要在线程之间来回切换。
3. 需要考虑线程操作对程序的影响,如线程挂起,中止等操作对程序的影响。
4. 线程使用不当会发生很多问题。

C#多线程编程

垃圾回收

GC就是垃圾回收器,一般来说系统会自动检测不会使用的对象或变量进行内存的释放,不需要手动调用
尝试通过调用Collect或WaitForPendingFinalizers方法强制进行垃圾回收操作将干扰垃圾回收算法,通常会恶化应用程序的内存使用。仅当您知道应用程序已用完只分配一次的大量内存时,才应调用Collect方法。例如,当应用程序已用完大缓存后,或者当大对话框关闭后而且您知道(或者有可能)将重新打开该对话框时,可调用Collect方法。
GC并不是能释放所有的资源。它不能自动释放非托管资源。
IDisposable接口,IDisposable接口定义了Dispose方法,这个方法用来供程序员显式调用以释放非托管资源。使用using 语句可以简化资源管理。

C#中IDisposable的用法:

class Database:IDisposable
    {
        public void visitDatabase()
        {
            Console.WriteLine("开始访问数据库");
        }
        public void Dispose()
        {
            Console.WriteLine("释放数据库连接资源");
        }
        //主函数,测试入口
        static void Main(string[] args)
        {
            //手工释放
            Database db = new Database();
            db.visitDatabase();
            db.Dispose();
            //using关键字自动释放
            using (Database db2 = new Database())
            {
                db2.visitDatabase();
            }
            //using关键字自动释放
            Database db3 = null;
            using (db3 = new Database())
            {
                db3.visitDatabase();
            }
        }
    }
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值