npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

uwebkoa

v1.0.8

Published

A high-performance web framework built on uWebSocket.js, wrapped in a Koa-like interface.

Readme

uWebKoa

Chinese Documentation - Next Generation High Performance Web Framework

uWebKoa is an asynchronous high-performance Node.js web framework based on uWebSockets.js, adopting a Koa-like middleware architecture design. It provides a cleaner API and better development experience while maintaining the high-performance characteristics of uWebSockets.js.

  • Native multi-CPU support
  • Native non-blocking I/O model
  • Streamlined JSON parsing
  • WebSocket hybrid deployment support
  • Static resource caching

Simplified interface mechanism and middleware architecture. Eliminates uWebSockets.js's complex interfaces and callback hell, while maintaining full compatibility with Koa ecosystem features including middleware, routing, and error handling.

Compared to Koa framework:

  • Over 60% performance improvement for POST requests with JSON parsing
  • Achieves 40,000 QPS on i5 12490F CPU
  • 30% improvement for standard GET requests
  • Theoretically better performance for complex tasks
  • Enable multi-threading/multi-process mode for long-response tasks to maintain performance

🚀 Core Features

Main Features:

  • Extreme Performance: 2-5x faster than Express/Koa
  • Koa-like API: Familiar interface and middleware architecture, low learning curve
  • Built-in Routing: Supports RESTful routing and parameter parsing
  • Static File Service: Direct memory buffer operations avoid data copying, efficient file transfer
  • Multi-core/Multi-thread Support: Automatic utilization of multi-core CPUs
  • Lightweight: Minimal core code with zero redundant dependencies

Performance Comparison

| Metric | uWebKoa QPS | Koa QPS | Improvement | |----------------|-------------|-----------|-------------| | GET Throughput | 38,822 RPS | 30,370 RPS| +28% | | POST JSON | 34,161 RPS | 20,927 RPS| +63% |

Test Environment: i5 12490F / 32GB DDR4 / Windows 11

Quick Start

Installation

npm install uWebKoa
# or
yarn add uWebKoa

Basic Example

import uWebKoa from 'uWebKoa';

const app = new uWebKoa();

// Middleware usage
app.use(async (ctx, next) => {
  console.log(`Request: ${ctx.method} ${ctx.url}`);
  await next();
});

// Route example
app.get('/', (ctx) => {
  ctx.body = 'Hello uWebKoa!';
});

app.get('/user/:id', (ctx) => {
  ctx.body = `User ID: ${ctx.request.params.id}`;
});

// Start server
app.listen(3000, () => {
  console.log('Server running at http://localhost:3000');
});

API Documentation

Application

import uWebKoa from 'uWebKoa';
const app = new uWebKoa();

Options:

  • rootDir: Project root directory (default: process.cwd())
  • staticDirs: Static file directory mapping
  • ssl: SSL configuration object ({ key_file_name, cert_file_name, passphrase })

Middleware

app.use(async (ctx, next) => {
  // Pre-request processing
  await next();
  // Post-request processing
});

Context

Each request creates a ctx object containing:

  • ctx.request: Request object
  • ctx.response: Response object
  • ctx.method: HTTP method
  • ctx.url: Request URL
  • ctx.query: Query parameters
  • ctx.params: Route parameters
  • ctx.body: Response body
  • ctx.status: HTTP status code

Routing

app.get('/path', ...handlers);
app.post('/path', ...handlers);
app.put('/path', ...handlers);
app.delete('/path', ...handlers);
app.get('/path/:id',...handlers);
app.get('/path/*',...handlers);

Support multiple handlers:

app.get('/user', 
  (ctx, next) => { /* Validation */ next() },
  (ctx) => { /* Processing */ }
);

Static File Service

app.serveStatic('/public', './static');

Response Methods

  • ctx.json(data): Send JSON response
  • ctx.sendFile(path): Send file
  • ctx.redirect(url): Redirect
  • ctx.throw(status, message): Throw error

Advanced Features

Multi-core Mode

app.listen(3000, { 
  cluster: true,
  workers: 4 // Optional, uses all CPU cores by default
});

Multi-thread Mode

// Thread mode (multi-threading)
app.listen(3000, {
  threads: true,
  workers: 8 // 8 worker threads
});

Note: Uses handle migration technology. Thread crashes may cause main process termination.

SSL/TLS Support

const app = new uWebKoa({
  ssl: {
    key_file_name: 'key.pem',
    cert_file_name: 'cert.pem',
    passphrase: 'your-passphrase' // Optional
  }
});

Native WebSocket Support

app.getUWebSocketApp().ws('/chat', {
  open: (ws) => {...},
  message: (ws, msg) => {...}
});

Socket.IO Integration

// Create socket.io instance
const io = new Server({
  cors: {
    origin: '*',
  },
});

// Get uWebSocket.js app instance
const uWebSocketApp = app.getUWebSocketApp();
io.attachApp(uWebSocketApp);
app.context.io = io; // Pass socket.io instance to context

app.get('/path/:id', (ctx) => {
  ctx.io.to(id).emit("server_notify_update", {}); 
});

Best Practices

  1. Middleware Order: Place general middleware before route-specific ones
  2. Error Handling: Use try/catch or error handling middleware
  3. Static Files: Enable cache for small files, streaming for large files
  4. Production: Enable multi-core mode for full CPU utilization

Migration Guide

From Koa

  1. Replace require('koa') with import uWebKoa from 'uwebkoa'
  2. Note ctx.res and ctx.req are native uWebSockets.js objects
  3. Use ctx.sendFile() instead of ctx.send() for file operations
  4. Request body parsing uses await ctx.parseBody() automatically

Example Project

import uWebKoa from 'uwebkoa';

const app = new uWebKoa();

// Logger middleware
app.use(async (ctx, next) => {
  const start = Date.now();
  await next();
  const ms = Date.now() - start;
  console.log(`${ctx.method} ${ctx.url} - ${ms}ms`);
});

// API Routes
app.get('/api/users', async (ctx) => {
  ctx.body = [{ id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }];
});

app.post('/api/users', async (ctx) => {
  await ctx.parseBody();
  // User creation logic
  ctx.status = 201;
  ctx.body = { success: true };
});

// Static Files
app.serveStatic('/public', './assets');

// Error Handling
app.use(async (ctx) => {
  ctx.status = 404;
  ctx.body = { error: 'Not Found' };
});

// Start Server
app.listen(3000, { cluster: true });

FAQ

  • Why choose uWebKoa over Koa or Express? uWebKoa maintains Koa's elegant API while providing significant performance improvements through the uWebSockets.js foundation, making it particularly suitable for high-concurrency scenarios.

  • Does it support WebSocket and Socket.io? The current version primarily focuses on HTTP services, with native WebSocket and Socket.io support planned for future releases.

  • How to access the raw request object? You can access uWebSockets.js' native objects through ctx.req and ctx.res. Additionally, app.getUWebSocketApp() retrieves the native uWebSockets.js application instance.

Contribution

We welcome issues and pull requests. Please ensure:

  • Consistent code style
  • Passing all tests
  • Comprehensive test coverage for new features

For questions or suggestions:

Open an issue on GitHub

  1. mail [email protected] with subject line "[uWebKoa] Your Subject"
  2. Please include detailed reproduction steps for bug reports and clear rationale for feature requests.

Stress Test

autocannon -c 100 -d 10 http://localhost:3000/api/users

License

MIT