Introduction
This chapter describes the basic structure, fundamentals, key features, admin tools, and environment variables of WebtoB.
1. Structure and Operation
WebtoB is structurally different from conventional web servers. Conventional web servers, such as Apache, have NCSA’s httpd structure. The httpd structure was designed to support only a moderate number of clients. The httpd structure lacks the flexibility to support a large growth in the number of clients.
Handling surge in users has been the top priority in designing WebtoB.
Conventional web servers generate a process for each incoming request from a client. As the number of clients increases, the number of server processes or threads must also increases. The server can quickly overload from the number of clients.
It is normal that surge in users causes server overload. Traditional approaches to address increased users depend on additional memory and CPUs. Rather than purchasing additional hardware to handle this growth, a better and more cost effective solution is required. The server must be flexible enough to support the increase in clients without interrupting its service in order to survive in the ever growing Web environment.
For WebtoB, the first priority in design was providing scalability to support growth in the number of clients. Comparing the structure of conventional web servers with WebtoB, one can understand why WebtoB is the solution for solving scalability problems.
1.1. Comparison with Conventional Web Servers
The structure of Apache was inherited from httpd. httpd is the oldest web server and has a Process per Request type structure. This mechanism generates a process whenever a user request is received. As the number of users increases, the number of processes also increases. Once the number of users grows beyond the server’s capability, the server overloads. The server overloads because of the limited number of processes that are available in each system and the increase in memory usage.
These shortcomings led to the development of commercial web servers with scalability for supporting the rapidly expanding web environment. The most commonly used technology is Multi-Threading. The Multi-Threading technology uses a thread, which has far less overhead than a process, to service a user request. Threading shows far superior performance than a process. Moreover, multiple threads can be allocated in a process, which leads to less overhead and requires less memory than process-based structures.
Nonetheless, multi-threading has problems of its own. Even though multi-threading is the superior technology, competing threads often result in deadlocks, affecting the stability of service. If a deadlock occurs in a thread structure, a thread cannot continue its service and may crash the entire system. This is a critical problem for a web server where performance and stability are vital.
The two previously described structures each have their strengths and weaknesses. They are polar opposites in relation to performance and stability. However, both performance and stability is essential to a web server because they directly affect the quality of service provided to the end user.
TmaxSoft has done extensive research in web server structures to satisfy both the performance and stability requirements when developing WebtoB. WebtoB employs the process-based structure for stability and the thread-based structure for performance. To improve performance, each process is designated to a specific task instead of creating independent processes, and task-specific threads are used for some specific processes. Each process is also provided with a secondary process with the focus on stability.
1.2. WebtoB Processes and Threads
The following are descriptions of WebtoB’s major processes.
-
WSM(WebtoB System Manager)
WSM is a WebtoB system operation process that manages operational information and all server processes such as HTL and HTH. WSM is the first process loaded onto memory upon startup of WebtoB, and the last process terminated upon shutdown.
-
HTL(HTTP Listener)
HTL is a listener process that manages connections between a client and WebtoB. When a client first connects to WebtoB, a connection is created between HTL and the client. For a service request, an internal connection with HTH processes the service.
-
HTH(HTTP Handler)
Also known as a client handler. It is a mediator between the client and the server’s task-processing process. HTH communicates with the server process to control data flow. It takes a service request from the client and processes the request. Once the result is ready, HTH retrieves the result and relays it to the client. HTH uses a high performance thread model that minimizes locking. The role of each thread is as follows:
Thread Type Description ACCESSLOG
Only one ACCESSLOG thread per HTH. Records accesslog after processing a HTTP(S) request.
WORKER
Processes HTML requests, SSL, Compression, etc.
SENDFILE
Sends a blocking HTML request to the client.
-
PHPS(PHP Server)
PHP server process for PHP requests.
-
CGIS(CGI Server)
CGI server process for CGI requests.
-
SSIS(SSI Server)
SSI server process for SSI requests.
2. Features
The features of WebtoB are as follows.
2.1. Caching
Caching is a feature available in many web servers. Most web servers support disk caching, which retrieves data from external machines and saves the data to the local disk. When clients request this data, the data can be accessed from the local disk instead of the external machine. Known as Proxy, other web servers have this feature and it effectively boosts the performance of the web server.
WebtoB uses caching in a more effective manner. When user sends a request, WebtoB selects resources that are frequently accessed and allocates them in the memory.
Currently, many web service providers use high-end servers with multiple CPUs and gigabytes of memory. Since processing bottlenecks generally come from the CPU, memory is not fully utilized. In fact, only 70-80% of memory is utilized depending on the CPU’s processing power.
Memory Caching in WebtoB improves performance by utilizing the unused vacant memory to cache frequently used resources. Because the data transfer rate of memory is 40-60% faster than disk, memory caching can result in significant performance enhancement. Memory cache sizes can be adjusted based on available free memory.
In addition, research results show that most user requests target specific sets of resources. Thus, even small memory caching can result in a significant performance boost.
2.2. WBAPI
WBAPI is a set of multi-purpose internal functions provided by WebtoB
WBAPI can convert existing CGI applications. Although CGI application can be easily developed, it is architecturally inefficient. Because of performance issues, CGI application cannot service a large number of users. CGI application based sites experiencing a flood of user requests have problems with service continuity. The CGI application can be redeveloped using a different technology or the hardware can be upgraded to deal with continuity issues.
WebtoB provides a revolutionary WBAPI function that can convert a CGI application into a WebtoB service. The conversion improves CGI applications by providing performance levels similar to Servlets and other script languages. WBAPI can also be used inside WebtoB to call the TP-Monitor’s Service Routine.
2.3. Calling TP-Monitor Tmax Service
When Tmax Service is called by a browser in WebtoB, a request must be in a specific format. This format is the same as a CGI request. However, WebtoB is required in order to configure the request to be recognized as a Tmax service.
For example, a Tmax Service is defined in the "/tmax" directory under WebtoB. Inside that directory, there is a service named service1. service1 can be requested from the browser as follows:
http://www.tmax.co.kr/tmax/service1
2.4. Extension Management
Most web servers define a default set of standardized Mime Types. Other data or applications must also be defined in the web server for proper transmission. If a user wants to define a new data type, a corresponding MIME Type must be also defined. WebtoB provides a manager to help define these data types. Also in the manager, data extensions can be modified and new extensions can be defined.
3. Management Tool
WebtoB provides management tools to manage engine and server processes as follows:
Management Tool | Description |
---|---|
wsadmin |
Manages the entire WebtoB system. It provides system information and performs administrative tasks. |
wscfl |
Compiles text-based configuration files to binary format. |
wsuncfl |
Converts compiled binary format files to text-based configuration files. |
wsmkpw |
Generates an authentication file consisting of encrypted user and password information. |
wsmkppd |
Creates a file that contains the passphrase password used to specify "file:<passphrase file path>" in the *SSL.PassPhraseDialog configuration. |
4. Environment Variables
The following table describes the environment variables provided by WebtoB.
Environment Variable | Description |
---|---|
WEBTOBDIR |
Configures the information of the WebtoB installation directory. (Required) |
WEBTOB_LICENSE |
Configured when license file name is changed. (Default value: license.dat) |
WEBTOB_RAC_PORT |
Must be configured when the port number used by wsracd is changed. (Default value: 3333) |
WEBTOB_PREFER_IPV6 |
Configure this to 'Y' or '1' when IPv6 address is used. |
"${WEBTOBDIR}/lib" is the location of the WebtoB shared libraries. The path must be added to the following environment variables using the system library path.
Environment Variable | Description |
---|---|
LD_LIBRARY_PATH |
A typical system library path of Linux/UNIX type systems. |
LD_LIBRARY_PATH_64 |
When 64-bit WebtoB is used in Solaris(SunOS), this system library path is applied. |
SHLIB_PATH |
When 32-bit WebtoB is used in HP-UX, this system library path is applied. |
5. Directory Structure
The following describes the WebtoB Directory structure.
WebtoB |-- bin |-- lib |-- usrinc |-- ap |-- config |-- path |-- log |-- docs |-- license
- bin
-
Contains executable files (wsm, wscfl, wsracd, wsgst, wsboot, wsdown, etc.)
- lib
-
Contains library files.
- usrinc
-
Contains API header files.
- ap
-
Contains application files.
- config
-
Contains WebtoB configuration files.
- path
-
Where the named pipe for process internal communication is created.
- log
-
Contains log files.
- docs
-
Contains the HTML documents registered by WebtoB by default.
- license
-
Contains the WebtoB license file.
6. License Specific Functions
WebtoB provides the following functions according to the license type.
License Type | Description |
---|---|
TRIAL |
Trial license. Any WebtoB installed using the installer contains a default trial license. Supports a single HTH, and a maximum of 5 users. |
BASE |
For use as embedded in JEUS. Only supports a single HTH. In a UNIX/Linux environment, JSVPort is not used since only named pipes can be used to connect to JEUS. |
STANDARD |
One or more HTHs are supported. Can connect to JEUS without limitations and supports most WebtoB functions. |
ENTERPRISE |
Supports the following functions in addition to all of those provided in the STANDARD version.
|