Setting up a Nikola site is really easy. You will need a few minutes’ time and a Python (3.3+; 2.7 partially supported) interpreter.
There are multiple ways to install Nikola.
pipin a virtualenv. We recommend installing the
"Nikola[extras]"distribution to access some extra features, but you can drop the
[extras]specifier if you don’t want them.
Nikola is free open-source software, under the MIT license.
Nikola supports Windows! Keep in mind, though, that there are some caveats:
py -m pip install virtualenv
Pillowrequire compiled extensions. Fortunately, they should work out of the box. In case the wheels fail to install, wait a few days, install a slightly older version, or use the unofficial wheels by Christoph Gohlke.
\as path separator (instead of
\r\n) as the line separator (instead of LF
Installing Nikola on macOS is easy. You can use Homebrew, MacPorts, Fink, or perform a standalone installation using the system Python. For future proof installations that do support all features using Python 3.3+ over macOS system Python is recommended.
brew install python3
sudo pip3 install virtualenv
virtualenv. Your virtualenvs may need to be recreated if you update Python.
Nikola is packaged for some Linux distributions, you may get that instead of installing via
pip. Keep in mind that those packages might be outdated and that we don’t support versions that are too old. Proceed with care!
You should not need to compile any C extension modules to run Nikola. Both lxml and Pillow have pre-compiled wheels available for Windows, macOS and Linux (compatible with all distributions).
However, if pip still attempts to compile those packages, you may need to do the following:
pip install -U pip setuptools wheel(on Windows, use
py -m pip)
Python.h, you need to install development packages for Python (eg. python3-dev or python3-devel).
You can also install Nikola from GitHub. This will get you the code that is still under development. It probably has bugs, but there are often new features or bugfixes.
$ pip install "git+https://github.com/getnikola/nikola#egg=Nikola[extras]"
You can also use tarballs downloaded from GitHub, or
pip install -e with a local clone.
A Docker image is available. It isn’t official, but it’s based on official Arch Linux packages.
You can also use Snapcraft if you are using a supported distro:
Or, if you want the latest version from GitHub:
# snap install nikola
# snap install nikola --edge
Some extra setup may be necessary. For a list of caveats, see the announcement blog post.
$ virtualenv3 nikola Note: The command might be different in some environments. You might need to use one of the following instead: virtualenv virtualenv-3.x (where x is your Python version) virtualenv -p /usr/bin/python3 Using base prefix '/usr' New python executable in nikola/bin/python3 Also creating executable in nikola/bin/python Installing setuptools, pip, wheel...done. $ cd nikola $ source bin/activate $ pip install --upgrade setuptools pip Note: Updating pip and setuptools is recommended. On Windows, use py -m pip install for both steps. $ pip install --upgrade "Nikola[extras]" ...snip... Successfully installed Nikola
After installing Nikola, you should create a site. A site is a collection of all assets needed to create your site: configuration, posts, pages, images, and all other files and customizations. This is the important data, so put it where you put that kind of things.
To create a site, you need to run
nikola init --demo <directory_name>. A friendly wizard will be launched, letting you configure your site easily. The
--demo option is used to fill your site with some demo content. (If you do not want the wizard, use the
$ nikola init --demo my_first_site Creating Nikola Site ==================== This is Nikola. We will now ask you a few easy questions about your new site. If you do not want to answer and want to go with the defaults instead, simply restart with the `-q` parameter. --- Questions about the site --- Site title [My Nikola Site]: My First Nikola Site ...a couple more questions... That's it, Nikola is now configured. Make sure to edit conf.py to your liking. If you are looking for themes and addons, check out https://themes.getnikola.com/ and https://plugins.getnikola.com/. Have fun! INFO: init: A new site with example data has been created at my_first_site. INFO: init: See README.txt in that folder for more information.
You can now build the site you created. Just run
nikola build. The output directory will then be filled with the contents of your site, which is now ready to deploy.
$ cd my_first_site $ nikola build Scanning posts....done! . render_galleries:output/galleries . render_galleries:output/galleries/demo . render_galleries:output/galleries/index.html . render_galleries:output/galleries/rss.xml . render_galleries:output/galleries/demo/tesla4_lg.thumbnail.jpg ...and many more files in between... . render_tags:output/categories/cat_nikola.xml . render_pages:output/stories/social_buttons/index.html . render_pages:output/stories/quickref/index.html . render_tags:output/categories/python.xml . generate_rss:output/rss.xml . render_pages:output/stories/a-study-in-scarlet/index.html . sitemap:output/sitemap.xml . sitemap:output/sitemapindex.xml . robots_file:output/robots.txt
Your site currently contains demo content — that is, some Nikola documentation, a demo gallery and listing, and a blog post welcoming you.
You should make it more interesting and personal. Write your own post!
To do that, you can just use
nikola new_post -e. (The
-e option will open the post in your text editor of choice; many more options are available)
The command will create the file for you in the right place, with the metadata headers and a writing prompt.
By default, Nikola creates posts in reStructuredText. You can read the reStructuredText Primer to get accustomed to the syntax. You can also use many other input formats; to do this, your site needs some special configuration.
If you want a static site that does not have any blog-related elements, see our Creating a Site (Not a Blog) with Nikola guide.
$ nikola new_post -e Creating New Post ----------------- Title: My First Blog Post! Scanning posts....done! INFO: new_post: Your post's text is at: posts/my-first-blog-post.rst
When you’re done writing your post, you must rebuild your site to make it visible on your site. Run
nikola build again.
Note that the list of files is much shorter now: Nikola does fast, incremental rebuilds (courtesy of doit). Nikola built only the pages for this post, the indexes, the feeds, and the previous post (to add a Next post navigation button). All the demo pages and assets were left untouched, saving you time and resources (it does not have to work on building some larger things, and
rsync will not have to upload everything)
$ nikola build Scanning posts....done! . render_posts:timeline_changes . render_posts:cache/posts/my-first-blog-post.html . render_sources:output/posts/my-first-blog-post/index.rst . render_archive:output/2015/index.html . render_archive:output/archive.html . render_indexes:output/index.html . render_pages:output/posts/welcome-to-nikola/index.html . generate_rss:output/rss.xml . render_pages:output/posts/my-first-blog-post/index.html . sitemap:output/sitemap.xml . sitemap:output/sitemapindex.xml
You’re done! You just created a Nikola site, wrote your first post and built your site. Congratulations!
nikola serve --browser to start the development server and open your site in a web browser. Press Ctrl+C to stop the server.
$ nikola serve --browser INFO: serve: Serving HTTP on 0.0.0.0 port 8000... INFO: serve: Opening http://0.0.0.0:8000/ in the default web browser...
conf.pyfile to your liking.
Input formats other than reStructuredText need some configuration, which has been described in The Nikola Manual.
When you’re done exploring, you should remove the demo content before deploying it to your server. Remove the demo stories, welcome post, demo gallery and listing manually. Run
nikola build to make them disappear from the archives. Note that this is not enough; you need to delete the now orphaned files. Nikola can do it for you — run
nikola check --clean-files. Note that this command will delete all files in the output directory it does not know about, which can be dangerous — please back up your files or find out what will be deleted by using
Hint: files in the
files/ directory are copied to the output directory as-is.
The development server (
nikola serve) should not be used outside of your local network. Instead, you should use a more serious web server. Nikola sites work on any web server which can host html files. You can use shared hosting, your own server (VPS/dedicated), GitHub Pages, or any other service that lets you host a website. For more details on deployment and related configuration, see the Deployment section in the Handbook.