https://blogs.technet.microsoft.com/askperf/2007/06/19/basic-printing-architecture/

Printer sharing, information retrieval, and data storage are among the most frequently used network services.  This also means that when something major happens to a print server or file server – lots of people are adversely affected.  Issues with Print Servers and the Print Spooler are very common issues for the Performance team.  So today, we’re going to kick off our series of posts on Printing with an overview of the Windows Printing Architecture and the Print Spooler.

Broken down into basic elements, the Windows printing architecture consists of a print spooler and a set of print drivers.  The print spooler is the primary component of the printing interface.  Most administrators are familiar with the spooler as an executable file (spoolsv.exe) that manages the printing process.  In a default configuration, the spooler is loaded at system startup and continues to run until the operating system is shut down.  The print spooler consists of a set of Microsoft and vendor components that perform the following tasks:

  • Should a print job be handled locally or across a network?
  • Accepting a data stream created by GDI, in conjunction with a printer driver, for output on a particular printer type
  • Spooling the data to a file
  • Selecting the first available physical printer in a logical printer queue
  • Converting a data stream from a spooled format such as EMF to a format that can be sent to the printer hardware (such as PCL)
  • Sending a data stream to printer hardware
  • Maintaining the registry database for spooler components and printer forms

Below is a simplified view of the print spooler components.  When looking at this diagram, if the printer hardware is local to the system, then the “client” and “server” pieces are all on the same machine.

Application – The print application creates a print job by calling Graphics Device Interface (GDI) functions

GDI – GDI includes user-mode and kernel-mode components.  The user-mode component, Microsoft Win32 GDI, is used by Win32 applications that require graphics support.  The kernel-mode component, the graphics engine, exports services and functions that graphics device drivers can use

Winspool.drv – This is the client interface into the spooler.

Spoolsv.exe –  This is the spooler’s API server.  It is implemented as a service when the OS is started

Spoolss.dll – Spoolss.dll acts as a router, determining which print provider to call based on a printer name or handle supplied with each function call.  It then passes the function call to the correct provider.

OK – so let’s discuss print providers.  The print provider is responsible for several functions, including directing print jobs to local or remote print devices and print queue management operations such as starting, stopping and enumerating print queues.  Print providers implement a common set of capabilities that are defined by a set of API functions.  These functions are called by spoolss.dll.  The diagram below illustrates possible flow paths involving different print providers.

The following print providers are supplied by Microsoft in Windows 2000, XP & Windows Server 2003:

localspl.dll – this is the local print provider which handles all print jobs directed to local printers

win32spl.dll – this is the Windows network print provider.  All print jobs directed to remote servers and handled by this provider.  When the job arrives at the remote server it is passed to the server’s local print provider

nwprovau.dll – Novell NetWare print provider

inetpp.dll – HTTP print provider which handles print jobs sent to a URL

Printer manufacturers may also create their own network print providers.

And that brings us to Print Processors.  Print processors are user-mode DLL files that convert the spooled data from a print job into a format that is understood by a print monitor.  When a print job is spooled, the data is contained in a spool file.  The print processor reads the file, performs the conversion on the data stream and writes the converted data to the spooler.  The spooler sends the data to the correct print monitor.  Print processors are associated with printer drivers during driver installation.  The default Print Processor provided with the operating system is winprint.dll.

Lastly, let’s talk about Print Monitors.  These are user-mode DLL’s responsible for directing a print data stream from the spooler to an appropriate port driver.  When we talk about print monitors we are actually referring to two different types of monitor.  First, there is the language monitor which provides a full-duplex communications path between the print spooler and bi-directional printers that are capable of providing software-accessible status information.  In addition, the language monitors add printer control information to the data stream.  It is important to note that Language monitors can be used to add any post spooling processing.  In addition to the Language monitors, we also have Port monitors.  These are responsible for providing a communications path between the user-mode print spooler and the kernel-mode port drivers that access I/O port hardware.  Port monitors are, as the name suggests, responsible for management and configuration of the printer ports on a server.

And that will do it for our look at the Basic Printing Architecture.  In future posts, we will be looking at drivers, troubleshooting and policies.  Until next time …

Additional Resources:

– CC Hameed

Basic Printing Architecture的更多相关文章

  1. Printing Architecture

    Printing Architecture http://www.codeproject.com/Articles/8916/Printing-Architecture     This articl ...

  2. Basic Router Architecture

    from the book principles and practices of interconnection networks  the chapter router architecture ...

  3. Struts 2 Tutorial Basic MVC Architecture

    Model View Controller or MVC as it is popularly called, is a software design pattern for developing ...

  4. Chromium Graphics: Compositor Thread Architecture

    Compositor Thread Architecture <jamesr, enne, vangelis, nduca> @chromium.org Goals The main re ...

  5. Nginx Tutorial #1: Basic Concepts(转)

    add by zhj: 文章写的很好,适合初学者 原文:https://www.netguru.com/codestories/nginx-tutorial-basics-concepts Intro ...

  6. Framework for Graphics Animation and Compositing Operations

    FIELD OF THE DISCLOSURE The subject matter of the present disclosure relates to a framework for hand ...

  7. Command and Query Responsibility Segregation (CQRS) Pattern 命令和查询职责分离(CQRS)模式

    Segregate operations that read data from operations that update data by using separate interfaces. T ...

  8. RNN 入门教程 Part 4 – 实现 RNN-LSTM 和 GRU 模型

    转载 - Recurrent Neural Network Tutorial, Part 4 – Implementing a GRU/LSTM RNN with Python and Theano ...

  9. bluetooth service uuid

    转自:https://www.bluetooth.com/specifications/assigned-numbers/service-discovery service discovery ​​​ ...

随机推荐

  1. 给Eclipse提速的7个技巧(转载的)

      大约一个月前,我发表了一篇博客,其中介绍了对Eclipse的爱与恨. 有些人问我如何给Eclipse提速,这篇文章就来讨论这个问题.顺带提一下,这篇文章不是比较IDE,所以不要说你讨厌某个IDE而 ...

  2. MyBatis(1):MyBatis入门

    MyBatis是什么 MyBatis是什么,MyBatis的jar包中有它的官方文档,文档是这么描述MyBatis的: MyBatis is a first class persistence fra ...

  3. Retina 屏移动设备 1px解决方案

    做移动端H5页面开发时都会遇到这样的问题,用 CSS 定义 1px 的实线边框,在 window.devicePixelRatio=2  的屏幕上会显示成 2px,在 window.devicePix ...

  4. Flashback Version Query、Flashback Transaction Query快速闪回细粒度数据

    Flashback Version Query 闪回版本查询 使用Flashback Version Query  返回在指定时间间隔或SCN间隔内的所有版本,一次commit命令就会创建一个版本. ...

  5. [转] thrift的使用介绍

    http://gemantic.iteye.com/blog/1199214 一.About  thrift   二.什么是thrift,怎么工作? 三.Thrift  IDL 四.Thrift   ...

  6. Java基础知识强化92:日期工具类的编写和测试案例

    1. DateUtil.java,代码如下: package cn.itcast_04; import java.text.ParseException; import java.text.Simpl ...

  7. 3_Linux_文件搜索指令

    .3文件搜索命令 1)which 查找一个命令所在的路径 whereis 提供命令的帮助文件的信息 whatis 显示命令的概要信息whatis ls which提供命令的别名信息 2)find,基本 ...

  8. poj 1988 Cube Stacking && codevs 1540 银河英雄传说(加权并茶几)

    #include<iostream> #include<cstdio> #include<cstring> #define maxn 30010 using nam ...

  9. jquery插件--多行文本缩略

    1.webkit内核多行缩略样式 text-overflow:ellipsis; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orie ...

  10. sql 判断表、列、视图等是否存在

    1 判断数据库是否存在 if exists (select * from sys.databases where name = '数据库名')     drop database [数据库名] 2 判 ...