Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1645148
  • 博文数量: 201
  • 博客积分: 2812
  • 博客等级: 少校
  • 技术积分: 3029
  • 用 户 组: 普通用户
  • 注册时间: 2011-01-18 18:28
个人简介

从事数据库工作多年,目前看好分布式NeSQL/HTAP数据库在企业客户市场的发展。未来的主要方向是——致力于 NewSQL/HTAP 数据库的推广普及。

文章存档

2016年(1)

2015年(8)

2014年(23)

2013年(50)

2012年(32)

2011年(87)

分类: Sybase

2012-07-02 15:49:14

   在ASE中,一个任务(Task)是ASE内部的一个可执行程序(execuable)。例如:user connections(client tasks)、daemons(比如,housekeeper tasks)和kernel tasks(比如,I/O handling)。
 在ASE中每个任务都有一个kernel process id ,即KPID。
   ASE调度Tasks到threads(User Task和Service Tasks调度到Engine Threads/Multiplexed Threads,System Tasks调度到RTC Threads)。ASE的tasks包括如下几种:
 
   1. User tasks
     这种任务代表了用户连接(user connections),并且能够执行用户的SQL查询。一个isql连接就是一个user task的例子。
 
   2. Service tasks
     这种任务不会与用户关联,并且不会发出/处理用户查询。Service tasks包括housekeeper tasks、checkpoints、replication agent threads等等。.
 
   3. System tasks
     系统任务是指ASE内核级的service tasks(kernel-level versions of service tasks). System tasks包括I/O handlers、the clock handler、cluster membership service、IP link monitor, and so on.
 
   在ASE中,任务(task,又叫做process)有四种状态:running、runnable、 sleeping和 blocked。当一个任务不是运行状态(running,即在CPU上执行)时,它可能处于如下三种状态之一:
   (1) Waiting on the CPU (the “runnable” state)
   (2) Sleeping because of disk or network I/O
   (3) Blocked on a resource (a lock, semaphore, spinlock,日志满而阻塞等等)
 
   “密切关系(Affinity)”是指特定的ASE 任务(tasks)只能运行在特定的引擎上(这种“密切关系”又叫做task affinity) ,特定的引擎为一个特定的任务(连接)处理network I/O (network I/O affinity),或者特定的引擎只能运行在特定的CPU上(这种“密切关系”又叫做engine affinity)。
   在“process mode”下,一个ASE连接(即client task)与接收(accepted)连接的引擎有“network I/O affinity”(即task affinity),这个引擎必须为该连接做所有network I/O操作。
 
   在“threaded mmode”下,不存在“network I/O affinity”,因为任何引擎可以为任何连接执行network I/O操作,这可以降低上下文切换(context switching)、提高性能。
  
阅读(1836) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~