from small one page howto to huge articles all in one place

search text in:




Other .linuxhowtos.org sites: www.linuxhowtos.org
toolsntoys.linuxhowtos.org



Last additions:
How to make X listen on port 6000

How to make X listen on port 6000

words:

34

views:

84876

userrating:

average rating: 1.2 (52 votes) (1=very good 6=terrible)


May, 25th 2007:
April, 26th 2007:
Apr, 10th. 2007:
Druckversion . pdf icon
You are here: Misc

Speeding up the boot process (next generation)

The idea is to preload the useful files into kernel buffer cache before they are needed. Since I/O can happen parallel to the other CPU intensive tasks during bootup, this leads to faster bootup and faster startup time for your chosen applications. Other projects use static lists to preload the files.

This tutorial uses an automated process of generating the "useful" prefetch database.

This is /etc/init.d/my-readahead.
Code:

#!/sbin/runscript
# Copyright 1999-2006 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: $

depend() {
        before syslog-ng
}

start() {
        ebegin "Starting readahead ROYALE"
        cat /etc/conf.d/* > /dev/null 2>&1 &
        cat /usr/lib/gconv/gconv-modules.cache > /dev/null 2>&1 &
        cat /usr/share/icons/gnome/icon-theme.cache > /dev/null 2>&1 &
        cat /usr/share/icons/hicolor/icon-theme.cache > /dev/null 2>&1 &
        cat `cat /etc/conf.d/sofile-list.load` > /dev/null 2>&1 &
        if [ -f /forcesampler ];then
                /usr/sbin/sample-init-process /etc/conf.d/sofile-list.load &
                rm -f /forcesampler
        fi 
        eend 0
}

stop() {
        eend 0
}

The executable shell script /usr/sbin/sample-init-process:
Code:

 #!/bin/bash
final_db="$1"

# total number of lists to keep in /etc/conf.d/
total_to_keep=4

# total number of samples to make in /forcesampler boot.
# It will take twice this amount of seconds to finish sampling.
total_samples_per_boot=200

# touch empty file if not there
[ ! -f "$final_db" ] && touch "$final_db"

let i=0
while [ "$i" -ne "$total_to_keep" ] ; do
        if [ ! -f "$final_db$i" ] ; then
                break;
        else
                j=$((i+1))
                if [ "$j" = "$total_to_keep" ] ;then
                        j=0
                fi
                if [ -f "$final_db$j" -a "$final_db$i" -nt "$final_db$j" ];then
                        i=$((j))
                        break;
                fi
        fi
        i=$((i+1))
done
if [ "$i" = "$total_to_keep" ] ;then
        i=0
fi

slot="$i"
cp "$final_db" "$final_db$i"

function collect_sample()
{
        lsof | awk '{if ($5=="REG") {if (match($9,".so") || match($9,".conf") \
        || match($9,"/bin/") || match($9,"ttf") || match($9,"libexec")) \
        print $9}}' | sort | uniq >> $1
}

collect_sample /tmp/init_sample1

i=0 
while [ "$i" -ne "$total_samples_per_boot" ] ; do
        collect_sample /tmp/init_sample2
        cat /tmp/init_sample1 /tmp/init_sample2 | sort | uniq > /tmp/init_sample3
        mv /tmp/init_sample3 /tmp/init_sample1
        sleep 1
        i=$((i+1))
done

cat /tmp/init_sample1 "$final_db$slot" | sort | uniq > "$final_db"

rm -f /tmp/init_sample[123]
And then do this:
Code:
chmod +x /usr/sbin/sample-init-process
rc-update add my-readahead default
touch /forcesampler

What you have done is asked my-readahead to create a sampler process which samples what files (fonts, binaries, libraries, configs) are in use, every second. It collects 200 samples (will be busy for at least 10 minutes after boot) and keeps updating the database with a list of useful files.

Once you boot after this the first time, you will probably see a slow down because its collecting samples for use on the next and subsequent boots. Use your system as you normally would. Open firefox, gaim, OO or whatever. Once the sampler script has finished ('ps -aef|grep sample-init-process' will tell you if its running), reboot. Now this and all subsequent boots will be much faster.

If it takes too long for the sample-init-process to finish, reduce the total_samples_per_boot variable in the sampler script to 100 and try again by touching /forcesampler.

In future, whenever you feel like updating the prefetch database, just 'touch /forcesampler' and database will be updated on next reboot.

based on http://forums.gentoo.org/viewtopic-t-478491.html, some script modifications done.

back



Support us on Content Nation

New Packages

- as rdf newsfeed
- as rss newsfeed
- as Atom newsfeed
2026-05-02
crossdev - 20260501
Ebuild name:

sys-devel/crossdev-20260501

Description

Gentoo Cross-toolchain generator

Added to portage

2026-05-02

dropbox - 250.4.3245
Ebuild name:

net-misc/dropbox-250.4.3245

Description

Dropbox daemon (pretends to be GUI-less)

Added to portage

2026-05-02

genius - 1.0.27-r1
Ebuild name:

sci-mathematics/genius-1.0.27-r1

Description

Genius Mathematics Tool and the GEL Language

Added to portage

2026-05-02

geolith-jg - 0.4.1
Ebuild name:

games-emulation/geolith-jg-0.4.1

Description

Jolly Good Neo Geo AES/MVS/CD/CDZ Emulator

Added to portage

2026-05-02

jgrf - 1.4.0
Ebuild name:

games-emulation/jgrf-1.4.0

Description

The Jolly Good Reference Frontend

Added to portage

2026-05-02

libgedit-amtk - 5.10.0
Ebuild name:

gui-libs/libgedit-amtk-5.10.0

Description

Actions, Menus and Toolbars Kit for GTK applications

Added to portage

2026-05-02

libgedit-gfls - 0.4.1
Ebuild name:

gui-libs/libgedit-gfls-0.4.1

Description

A module dedicated to file loading and saving

Added to portage

2026-05-02

libgedit-gtksourceview - 299.7.0
Ebuild name:

gui-libs/libgedit-gtksourceview-299.7.0

Description

Gedit Technology - Source code editing widget

Added to portage

2026-05-02

libgedit-tepl - 6.14.0
Ebuild name:

gui-libs/libgedit-tepl-6.14.0

Description

GtkSourceView-based text editors and IDE helper library

Added to portage

2026-05-02

libgpg-error - 1.60
Ebuild name:

dev-libs/libgpg-error-1.60

Description

Contains error handling functions used by GnuPG software

Added to portage

2026-05-02

libpeas - 1.38.1
Ebuild name:

dev-libs/libpeas-1.38.1

Description

A GObject plugins library

Added to portage

2026-05-02

libsdl2 - 2.32.68
Ebuild name:

media-libs/libsdl2-2.32.68

Description

Simple Direct Media Layer

Added to portage

2026-05-02

libsdl3 - 3.4.6
Ebuild name:

media-libs/libsdl3-3.4.6

Description

Simple Direct Media Layer

Added to portage

2026-05-02

nagios-mode - 0.4
Ebuild name:

app-emacs/nagios-mode-0.4

Description

Major mode for editing Nagios configuration files

Added to portage

2026-05-02

rygel - 45.1
Ebuild name:

net-misc/rygel-45.1

Description

Rygel is an open source UPnP/DLNA MediaServer

Added to portage

2026-05-02

strace - 7.0
Ebuild name:

dev-debug/strace-7.0

Description

Useful diagnostic, instructional, and debugging tool

Added to portage

2026-05-02

2026-05-01
apertium - 3.8.3-r2
Ebuild name:

sci-misc/apertium-3.8.3-r2

Description

Shallow-transfer machine Translation engine and toolbox

Added to portage

2026-05-01

apertium - 3.9.12
Ebuild name:

sci-misc/apertium-3.9.12

Description

Shallow-transfer machine Translation engine and toolbox

Added to portage

2026-05-01

awscli - 1.45.1
Ebuild name:

app-admin/awscli-1.45.1

Description

Universal Command Line Environment for AWS

Added to portage

2026-05-01

awscli-bin - 2.34.40
Ebuild name:

app-admin/awscli-bin-2.34.40

Description

command line interface for Amazon Web Services

Added to portage

2026-05-01

b2sdk - 2.11.0
Ebuild name:

dev-python/b2sdk-2.11.0

Description

Library to access Backblaze B2 cloud storage

Added to portage

2026-05-01

boto3 - 1.43.1
Ebuild name:

dev-python/boto3-1.43.1

Description

The AWS SDK for Python

Added to portage

2026-05-01

botocore - 1.43.1
Ebuild name:

dev-python/botocore-1.43.1

Description

Low-level, data-driven core of boto 3

Added to portage

2026-05-01

braintree - 4.43.0
Ebuild name:

dev-python/braintree-4.43.0

Description

Braintree Python Library

Added to portage

2026-05-01

difftastic - 0.69.0
Ebuild name:

dev-util/difftastic-0.69.0

Description

A structural diff that understands syntax.

Added to portage

2026-05-01

dist-kernel - 5.10.254
Ebuild name:

virtual/dist-kernel-5.10.254

Description

Virtual to depend on any Distribution Kernel

Added to portage

2026-05-01

dist-kernel - 5.15.204
Ebuild name:

virtual/dist-kernel-5.15.204

Description

Virtual to depend on any Distribution Kernel

Added to portage

2026-05-01

dist-kernel - 6.1.170
Ebuild name:

virtual/dist-kernel-6.1.170

Description

Virtual to depend on any Distribution Kernel

Added to portage

2026-05-01

dist-kernel - 6.12.85
Ebuild name:

virtual/dist-kernel-6.12.85

Description

Virtual to depend on any Distribution Kernel

Added to portage

2026-05-01

dist-kernel - 6.18.26
Ebuild name:

virtual/dist-kernel-6.18.26

Description

Virtual to depend on any Distribution Kernel

Added to portage

2026-05-01

dist-kernel - 6.6.137
Ebuild name:

virtual/dist-kernel-6.6.137

Description

Virtual to depend on any Distribution Kernel

Added to portage

2026-05-01

dist-kernel - 7.0.3
Ebuild name:

virtual/dist-kernel-7.0.3

Description

Virtual to depend on any Distribution Kernel

Added to portage

2026-05-01

ena-driver - 2.17.0
Ebuild name:

net-misc/ena-driver-2.17.0

Description

Amazon EC2 Elastic Network Adapter (ENA) kernel driver

Added to portage

2026-05-01

eog - 49.3
Ebuild name:

media-gfx/eog-49.3

Description

The Eye of GNOME image viewer

Added to portage

2026-05-01

freepg - 2.5.19
Ebuild name:

app-crypt/freepg-2.5.19

Description

Cross-distro GnuPG fork focused on OpenPGP compliance

Added to portage

2026-05-01

gdm - 49.2
Ebuild name:

gnome-base/gdm-49.2

Description

GNOME Display Manager for managing graphical display servers and user logins

Added to portage

2026-05-01

gdm-greeter - 0
Ebuild name:

acct-user/gdm-greeter-0

Description

User for GDM greeter specialized for elogind

Added to portage

2026-05-01

gentoo-kernel - 5.10.254
Ebuild name:

sys-kernel/gentoo-kernel-5.10.254

Description

Linux kernel built with Gentoo patches

Added to portage

2026-05-01

gentoo-kernel - 5.15.204
Ebuild name:

sys-kernel/gentoo-kernel-5.15.204

Description

Linux kernel built with Gentoo patches

Added to portage

2026-05-01

gentoo-kernel - 6.1.170
Ebuild name:

sys-kernel/gentoo-kernel-6.1.170

Description

Linux kernel built with Gentoo patches

Added to portage

2026-05-01

gentoo-kernel - 6.12.85
Ebuild name:

sys-kernel/gentoo-kernel-6.12.85

Description

Linux kernel built with Gentoo patches

Added to portage

2026-05-01

gentoo-kernel - 6.18.26
Ebuild name:

sys-kernel/gentoo-kernel-6.18.26

Description

Linux kernel built with Gentoo patches

Added to portage

2026-05-01

gentoo-kernel - 6.6.137
Ebuild name:

sys-kernel/gentoo-kernel-6.6.137

Description

Linux kernel built with Gentoo patches

Added to portage

2026-05-01

gentoo-kernel - 7.0.3
Ebuild name:

sys-kernel/gentoo-kernel-7.0.3

Description

Linux kernel built with Gentoo patches

Added to portage

2026-05-01

gentoo-kernel-bin - 5.10.254
Ebuild name:

sys-kernel/gentoo-kernel-bin-5.10.254

Description

Pre-built Linux kernel with Gentoo patches

Added to portage

2026-05-01

gentoo-kernel-bin - 5.15.204
Ebuild name:

sys-kernel/gentoo-kernel-bin-5.15.204

Description

Pre-built Linux kernel with Gentoo patches

Added to portage

2026-05-01

gentoo-kernel-bin - 6.1.170
Ebuild name:

sys-kernel/gentoo-kernel-bin-6.1.170

Description

Pre-built Linux kernel with Gentoo patches

Added to portage

2026-05-01

gentoo-kernel-bin - 6.12.85
Ebuild name:

sys-kernel/gentoo-kernel-bin-6.12.85

Description

Pre-built Linux kernel with Gentoo patches

Added to portage

2026-05-01

gentoo-kernel-bin - 6.18.26
Ebuild name:

sys-kernel/gentoo-kernel-bin-6.18.26

Description

Pre-built Linux kernel with Gentoo patches

Added to portage

2026-05-01

gentoo-kernel-bin - 6.6.137
Ebuild name:

sys-kernel/gentoo-kernel-bin-6.6.137

Description

Pre-built Linux kernel with Gentoo patches

Added to portage

2026-05-01

gentoo-kernel-bin - 7.0.3
Ebuild name:

sys-kernel/gentoo-kernel-bin-7.0.3

Description

Pre-built Linux kernel with Gentoo patches

Added to portage

2026-05-01

gjs - 1.88.0
Ebuild name:

dev-libs/gjs-1.88.0

Description

Javascript bindings for GNOME

Added to portage

2026-05-01

glycin - 2.1.1-r1
Ebuild name:

media-libs/glycin-2.1.1-r1

Description

Sandboxed and extendable image loading library

Added to portage

2026-05-01

gnome-control-center - 49.7
Ebuild name:

gnome-base/gnome-control-center-49.7

Description

GNOME's main interface to configure various aspects of the des

Added to portage

2026-05-01

gnome-mahjongg - 49.1.1
Ebuild name:

games-board/gnome-mahjongg-49.1.1

Description

Disassemble a pile of tiles by removing matching pairs

Added to portage

2026-05-01

gnome-maps - 49.5
Ebuild name:

sci-geosciences/gnome-maps-49.5

Description

A map application for GNOME

Added to portage

2026-05-01

gnome-remote-desktop - 49.3
Ebuild name:

net-misc/gnome-remote-desktop-49.3

Description

Remote desktop server which allows you to connect to your machin

Added to portage

2026-05-01

gnome-session - 49.2
Ebuild name:

gnome-base/gnome-session-49.2

Description

Gnome session manager

Added to portage

2026-05-01

gnome-session-openrc - 49.0
Ebuild name:

gnome-base/gnome-session-openrc-49.0

Description

Gnome session leader for OpenRC

Added to portage

2026-05-01

gnome-session-openrc - 49.0-r1
Ebuild name:

gnome-base/gnome-session-openrc-49.0-r1

Description

Gnome session leader for OpenRC

Added to portage

2026-05-01

gnome-settings-daemon - 49.1
Ebuild name:

gnome-base/gnome-settings-daemon-49.1

Description

Gnome Settings Daemon

Added to portage

2026-05-01

gnome-shell - 49.6
Ebuild name:

gnome-base/gnome-shell-49.6

Description

Provides core UI functions for the GNOME desktop

Added to portage

2026-05-01

gnome-shell-extension-bing-wallpaper - 53
Ebuild name:

gnome-extra/gnome-shell-extension-bing-wallpaper-53

Description

Change your wallpaper daily to the bing.com bac

Added to portage

2026-05-01

gnome-shell-extension-pop-shell - 1.2.0_p20260331
Ebuild name:

gnome-extra/gnome-shell-extension-pop-shell-1.2.0_p20260331

Description

Keyboard-driven layer for GNOME Shell w

Added to portage

2026-05-01

gnome-shell-extensions - 49.0
Ebuild name:

gnome-extra/gnome-shell-extensions-49.0

Description

JavaScript extensions for GNOME Shell

Added to portage

2026-05-01

gnome-sudoku - 49.5
Ebuild name:

games-puzzle/gnome-sudoku-49.5

Description

Test your logic skills in this number grid puzzle

Added to portage

2026-05-01

gnome-user-docs - 49.5
Ebuild name:

gnome-extra/gnome-user-docs-49.5

Description

GNOME end user documentation

Added to portage

2026-05-01

gnote - 49.4
Ebuild name:

app-misc/gnote-49.4

Description

Desktop note-taking application

Added to portage

2026-05-01

google-api-python-client - 2.195.0
Ebuild name:

dev-python/google-api-python-client-2.195.0

Description

Google API Client for Python

Added to portage

2026-05-01

google-auth - 2.50.0
Ebuild name:

dev-python/google-auth-2.50.0

Description

Google Authentication Library

Added to portage

2026-05-01

gsettings-desktop-schemas - 49.1
Ebuild name:

gnome-base/gsettings-desktop-schemas-49.1

Description

Collection of GSettings schemas for GNOME desktop

Added to portage

2026-05-01

h5utils - 1.13.2
Ebuild name:

sci-misc/h5utils-1.13.2

Description

Utilities for visualization and conversion of HDF5 files

Added to portage

2026-05-01

highs - 1.14.0-r1
Ebuild name:

sci-mathematics/highs-1.14.0-r1

Description

Modern solver for linear, quadratic, and mixed-integer programs

Added to portage

2026-05-01

icalendar - 7.1.0
Ebuild name:

dev-python/icalendar-7.1.0

Description

RFC 5545 compatible parser and generator of iCalendar files

Added to portage

2026-05-01

installkernel - 68
Ebuild name:

sys-kernel/installkernel-68

Description

Gentoo fork of installkernel script from debianutils

Added to portage

2026-05-01

ipyparallel - 9.1.0-r1
Ebuild name:

dev-python/ipyparallel-9.1.0-r1

Description

Interactive Parallel Computing with IPython

Added to portage

2026-05-01

mold - 2.41.0
Ebuild name:

sys-devel/mold-2.41.0

Description

A Modern Linker

Added to portage

2026-05-01

mutter - 49.5
Ebuild name:

x11-wm/mutter-49.5

Description

GNOME compositing window manager based on Clutter

Added to portage

2026-05-01

nautilus - 49.6
Ebuild name:

gnome-base/nautilus-49.6

Description

Default file manager for the GNOME desktop

Added to portage

2026-05-01

navi2ch - 1.8.4-r2
Ebuild name:

app-emacs/navi2ch-1.8.4-r2

Description

A navigator for the Japanese textboard 2ch

Added to portage

2026-05-01

nerd-icons - 0.1.0
Ebuild name:

app-emacs/nerd-icons-0.1.0

Description

Emacs Nerd Font Icons Library

Added to portage

2026-05-01

nginx-mode - 1.1.10
Ebuild name:

app-emacs/nginx-mode-1.1.10

Description

Emacs editing mode for Nginx config files

Added to portage

2026-05-01

nim-mode - 0.4.2_p20231101
Ebuild name:

app-emacs/nim-mode-0.4.2_p20231101

Description

Emacs major mode for the Nim programming language support

Added to portage

2026-05-01

node_exporter - 1.11.1
Ebuild name:

app-metrics/node_exporter-1.11.1

Description

Prometheus exporter for machine metrics

Added to portage

2026-05-01

notebook - 7.5.6
Ebuild name:

dev-python/notebook-7.5.6

Description

Jupyter Interactive Notebook

Added to portage

2026-05-01

nss-docker-ng - 1.2.0
Ebuild name:

sys-auth/nss-docker-ng-1.2.0

Description

NSS plugin for finding Docker containers by their ID or name

Added to portage

2026-05-01

orca - 49.7
Ebuild name:

app-accessibility/orca-49.7

Description

Extensible screen reader that provides access to the desktop

Added to portage

2026-05-01

papers - 49.6
Ebuild name:

app-text/papers-49.6

Description

A document viewer for the GNOME desktop

Added to portage

2026-05-01

paperwork-backend - 2.2.5-r1
Ebuild name:

app-text/paperwork-backend-2.2.5-r1

Description

Backend part of Paperwork (Python API, no UI)

Added to portage

2026-05-01

pch-session - 49.0
Ebuild name:

gnome-extra/pch-session-49.0

Description

Unofficial gnome based session with different default settings and ext

Added to portage

2026-05-01

pkgdev - 0.2.13
Ebuild name:

dev-util/pkgdev-0.2.13

Description

Collection of tools for Gentoo development

Added to portage

2026-05-01

plasma-meta - 6.6.0-r2
Ebuild name:

kde-plasma/plasma-meta-6.6.0-r2

Description

Merge this to pull in all Plasma 6 packages

Added to portage

2026-05-01

plasma-meta - 6.6.4-r1
Ebuild name:

kde-plasma/plasma-meta-6.6.4-r1

Description

Merge this to pull in all Plasma 6 packages

Added to portage

2026-05-01

ptyxis - 49.3
Ebuild name:

x11-terms/ptyxis-49.3

Description

A terminal for a container-oriented desktop

Added to portage

2026-05-01

pypugjs - 6.0.3
Ebuild name:

dev-python/pypugjs-6.0.3

Description

Pug (Jade) syntax adapter for Django, Jinja2 and Mako templates

Added to portage

2026-05-01

quadrapassel - 49.3
Ebuild name:

games-puzzle/quadrapassel-49.3

Description

Fit falling blocks together

Added to portage

2026-05-01

recurring-ical-events - 3.8.2
Ebuild name:

dev-python/recurring-ical-events-3.8.2

Description

Repeat ICalendar events by RRULE, RDATE and EXDATE

Added to portage

2026-05-01

rssguard - 5.1.0
Ebuild name:

net-news/rssguard-5.1.0

Description

Simple (yet powerful) news feed reader

Added to portage

2026-05-01

starship - 1.25.1
Ebuild name:

app-shells/starship-1.25.1

Description

The minimal, blazing-fast, and infinitely customizable prompt for any sh

Added to portage

2026-05-01

terraform - 1.15.0
Ebuild name:

app-admin/terraform-1.15.0

Description

A tool for building, changing, and combining infrastructure safely

Added to portage

2026-05-01

tinywl - 0.20.0
Ebuild name:

gui-wm/tinywl-0.20.0

Description

Added to portage

2026-05-01

trimesh - 4.12.2
Ebuild name:

dev-python/trimesh-4.12.2

Description

Python library for loading and using triangular meshes

Added to portage

2026-05-01

typer - 0.25.1
Ebuild name:

dev-python/typer-0.25.1

Description

Build great CLIs. Easy to code. Based on Python type hints

Added to portage

2026-05-01

vanilla-kernel - 5.10.254
Ebuild name:

sys-kernel/vanilla-kernel-5.10.254

Description

Linux kernel built from vanilla upstream sources

Added to portage

2026-05-01

vanilla-kernel - 5.15.204
Ebuild name:

sys-kernel/vanilla-kernel-5.15.204

Description

Linux kernel built from vanilla upstream sources

Added to portage

2026-05-01

vanilla-kernel - 6.1.170
Ebuild name:

sys-kernel/vanilla-kernel-6.1.170

Description

Linux kernel built from vanilla upstream sources

Added to portage

2026-05-01

vanilla-kernel - 6.12.85
Ebuild name:

sys-kernel/vanilla-kernel-6.12.85

Description

Linux kernel built from vanilla upstream sources

Added to portage

2026-05-01

vanilla-kernel - 6.18.26
Ebuild name:

sys-kernel/vanilla-kernel-6.18.26

Description

Linux kernel built from vanilla upstream sources

Added to portage

2026-05-01

vanilla-kernel - 6.6.137
Ebuild name:

sys-kernel/vanilla-kernel-6.6.137

Description

Linux kernel built from vanilla upstream sources

Added to portage

2026-05-01

vanilla-kernel - 7.0.3
Ebuild name:

sys-kernel/vanilla-kernel-7.0.3

Description

Linux kernel built from vanilla upstream sources

Added to portage

2026-05-01

zsdx - 1.13.0_p20240219
Ebuild name:

games-rpg/zsdx-1.13.0_p20240219

Description

Free 2D Zelda fangame

Added to portage

2026-05-01

zsxd - 1.13.0_p20251108
Ebuild name:

games-rpg/zsxd-1.13.0_p20251108

Description

Free 2D Zelda fangame parody

Added to portage

2026-05-01

rdf newsfeed | rss newsfeed | Atom newsfeed
Copyright 2004-2025 Sascha Nitsch Unternehmensberatung GmbH
- Copyright and legal notices -
Time to create this page: 40.7 ms