应用服务器优化技术

  • 分布式缓存
    • JBoss Cache
    • Memchached
  • 消息队列
    • RabbitMQ
    • Redis
  • 使用集群
  • 代码优化
    • 多线程
    • 垃圾回收

分布式缓存

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

JBoss Cache

应用服务器优化技术_第1张图片

Memchached

应用服务器优化技术_第2张图片

消息队列

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

应用服务器优化技术_第3张图片

应用服务器优化技术_第4张图片

RabbitMQ

.NET 环境中使用RabbitMQ

Redis

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

使用集群

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

代码优化

多线程

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

优点
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();
            }
        }
    }

你可能感兴趣的:(.net)