├── .github └── workflows │ └── gh-pages.yml ├── .gitignore ├── .gitmodules ├── LICENSE ├── README.md ├── archetypes └── default.md ├── config.toml.example ├── content ├── Contribution │ ├── Adding a Page │ │ └── _index.md │ ├── File Structure │ │ └── _index.md │ ├── Get Started │ │ └── _index.md │ ├── Modify a Page │ │ └── _index.md │ └── _index.md ├── Explanations │ └── _index.md ├── Getting Started │ ├── Difficulty Tiers │ │ └── _index.md │ ├── How To Self Host │ │ └── _index.md │ ├── Operating Systems │ │ └── _index.md │ ├── Reverse Proxies │ │ └── _index.md │ ├── Self-Hosted Alternatives │ │ └── _index.md │ ├── What Is Self-Hosting │ │ └── _index.md │ └── _index.md ├── Guides │ ├── DevOps Toolchains │ │ ├── Gitlab Kubernetes │ │ │ └── _index.md │ │ └── _index.md │ ├── Get a free domain name and certificate │ │ └── _index.md │ ├── Reverse Proxy Servers │ │ ├── Nginx │ │ │ └── _index.md │ │ └── _index.md │ ├── Virtual Private Networks │ │ ├── Wireguard │ │ │ └── _index.md │ │ └── _index.md │ ├── Webservers │ │ └── _index.md │ └── _index.md ├── _index.md └── tags │ ├── easy │ └── _index.md │ ├── hard │ └── _index.md │ └── normal │ └── _index.md ├── layouts └── partials │ ├── favicon.html │ └── logo.html └── static └── images ├── favicon.png └── logo.png /.github/workflows/gh-pages.yml: -------------------------------------------------------------------------------- 1 | name: Build 2 | on: 3 | push: 4 | branches: 5 | - main 6 | 7 | permissions: 8 | contents: read 9 | pages: write 10 | id-token: write 11 | 12 | jobs: 13 | build: 14 | runs-on: ubuntu-latest 15 | steps: 16 | - name: Checkout project 17 | uses: actions/checkout@v3 18 | - name: Checkout submodules 19 | run: | 20 | git submodule init 21 | git submodule update 22 | - name: Install build dependencies 23 | run: | 24 | sudo apt update 25 | sudo apt install hugo 26 | - name: Configure hugo 27 | run: | 28 | patch -o config.toml config.toml.example << EOF 29 | 1c1 30 | < baseURL = "http://localhost/" 31 | --- 32 | > baseURL = "https://r-selfhosted-wiki.github.io/wiki" 33 | EOF 34 | - name: Build page 35 | run: hugo 36 | - name: Upload atrifacts 37 | uses: actions/upload-artifact@v3 38 | with: 39 | path: public 40 | 41 | prepare_page: 42 | runs-on: ubuntu-latest 43 | needs: 44 | - build 45 | steps: 46 | - name: Retrieve build 47 | uses: actions/download-artifact@v3 48 | - name: Upload Pages Artifact 49 | uses: actions/upload-pages-artifact@v1.0.8 50 | with: 51 | path: artifact 52 | 53 | deploy: 54 | environment: 55 | name: github-pages 56 | url: ${{ steps.deployment.outputs.page_url }} 57 | runs-on: ubuntu-latest 58 | needs: prepare_page 59 | steps: 60 | - name: Deploy to GitHub Pages 61 | id: deployment 62 | uses: actions/deploy-pages@v2 63 | with: 64 | preview: true 65 | 66 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | config.toml 2 | .hugo_build.lock 3 | ./public/ -------------------------------------------------------------------------------- /.gitmodules: -------------------------------------------------------------------------------- 1 | [submodule "themes/hugo-theme-learn"] 2 | path = themes/hugo-theme-learn 3 | url = https://github.com/matcornic/hugo-theme-learn.git 4 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | Creative Commons Legal Code 2 | 3 | CC0 1.0 Universal 4 | 5 | CREATIVE COMMONS CORPORATION IS NOT A LAW FIRM AND DOES NOT PROVIDE 6 | LEGAL SERVICES. DISTRIBUTION OF THIS DOCUMENT DOES NOT CREATE AN 7 | ATTORNEY-CLIENT RELATIONSHIP. CREATIVE COMMONS PROVIDES THIS 8 | INFORMATION ON AN "AS-IS" BASIS. CREATIVE COMMONS MAKES NO WARRANTIES 9 | REGARDING THE USE OF THIS DOCUMENT OR THE INFORMATION OR WORKS 10 | PROVIDED HEREUNDER, AND DISCLAIMS LIABILITY FOR DAMAGES RESULTING FROM 11 | THE USE OF THIS DOCUMENT OR THE INFORMATION OR WORKS PROVIDED 12 | HEREUNDER. 13 | 14 | Statement of Purpose 15 | 16 | The laws of most jurisdictions throughout the world automatically confer 17 | exclusive Copyright and Related Rights (defined below) upon the creator 18 | and subsequent owner(s) (each and all, an "owner") of an original work of 19 | authorship and/or a database (each, a "Work"). 20 | 21 | Certain owners wish to permanently relinquish those rights to a Work for 22 | the purpose of contributing to a commons of creative, cultural and 23 | scientific works ("Commons") that the public can reliably and without fear 24 | of later claims of infringement build upon, modify, incorporate in other 25 | works, reuse and redistribute as freely as possible in any form whatsoever 26 | and for any purposes, including without limitation commercial purposes. 27 | These owners may contribute to the Commons to promote the ideal of a free 28 | culture and the further production of creative, cultural and scientific 29 | works, or to gain reputation or greater distribution for their Work in 30 | part through the use and efforts of others. 31 | 32 | For these and/or other purposes and motivations, and without any 33 | expectation of additional consideration or compensation, the person 34 | associating CC0 with a Work (the "Affirmer"), to the extent that he or she 35 | is an owner of Copyright and Related Rights in the Work, voluntarily 36 | elects to apply CC0 to the Work and publicly distribute the Work under its 37 | terms, with knowledge of his or her Copyright and Related Rights in the 38 | Work and the meaning and intended legal effect of CC0 on those rights. 39 | 40 | 1. Copyright and Related Rights. A Work made available under CC0 may be 41 | protected by copyright and related or neighboring rights ("Copyright and 42 | Related Rights"). Copyright and Related Rights include, but are not 43 | limited to, the following: 44 | 45 | i. the right to reproduce, adapt, distribute, perform, display, 46 | communicate, and translate a Work; 47 | ii. moral rights retained by the original author(s) and/or performer(s); 48 | iii. publicity and privacy rights pertaining to a person's image or 49 | likeness depicted in a Work; 50 | iv. rights protecting against unfair competition in regards to a Work, 51 | subject to the limitations in paragraph 4(a), below; 52 | v. rights protecting the extraction, dissemination, use and reuse of data 53 | in a Work; 54 | vi. database rights (such as those arising under Directive 96/9/EC of the 55 | European Parliament and of the Council of 11 March 1996 on the legal 56 | protection of databases, and under any national implementation 57 | thereof, including any amended or successor version of such 58 | directive); and 59 | vii. other similar, equivalent or corresponding rights throughout the 60 | world based on applicable law or treaty, and any national 61 | implementations thereof. 62 | 63 | 2. Waiver. To the greatest extent permitted by, but not in contravention 64 | of, applicable law, Affirmer hereby overtly, fully, permanently, 65 | irrevocably and unconditionally waives, abandons, and surrenders all of 66 | Affirmer's Copyright and Related Rights and associated claims and causes 67 | of action, whether now known or unknown (including existing as well as 68 | future claims and causes of action), in the Work (i) in all territories 69 | worldwide, (ii) for the maximum duration provided by applicable law or 70 | treaty (including future time extensions), (iii) in any current or future 71 | medium and for any number of copies, and (iv) for any purpose whatsoever, 72 | including without limitation commercial, advertising or promotional 73 | purposes (the "Waiver"). Affirmer makes the Waiver for the benefit of each 74 | member of the public at large and to the detriment of Affirmer's heirs and 75 | successors, fully intending that such Waiver shall not be subject to 76 | revocation, rescission, cancellation, termination, or any other legal or 77 | equitable action to disrupt the quiet enjoyment of the Work by the public 78 | as contemplated by Affirmer's express Statement of Purpose. 79 | 80 | 3. Public License Fallback. Should any part of the Waiver for any reason 81 | be judged legally invalid or ineffective under applicable law, then the 82 | Waiver shall be preserved to the maximum extent permitted taking into 83 | account Affirmer's express Statement of Purpose. In addition, to the 84 | extent the Waiver is so judged Affirmer hereby grants to each affected 85 | person a royalty-free, non transferable, non sublicensable, non exclusive, 86 | irrevocable and unconditional license to exercise Affirmer's Copyright and 87 | Related Rights in the Work (i) in all territories worldwide, (ii) for the 88 | maximum duration provided by applicable law or treaty (including future 89 | time extensions), (iii) in any current or future medium and for any number 90 | of copies, and (iv) for any purpose whatsoever, including without 91 | limitation commercial, advertising or promotional purposes (the 92 | "License"). The License shall be deemed effective as of the date CC0 was 93 | applied by Affirmer to the Work. Should any part of the License for any 94 | reason be judged legally invalid or ineffective under applicable law, such 95 | partial invalidity or ineffectiveness shall not invalidate the remainder 96 | of the License, and in such case Affirmer hereby affirms that he or she 97 | will not (i) exercise any of his or her remaining Copyright and Related 98 | Rights in the Work or (ii) assert any associated claims and causes of 99 | action with respect to the Work, in either case contrary to Affirmer's 100 | express Statement of Purpose. 101 | 102 | 4. Limitations and Disclaimers. 103 | 104 | a. No trademark or patent rights held by Affirmer are waived, abandoned, 105 | surrendered, licensed or otherwise affected by this document. 106 | b. Affirmer offers the Work as-is and makes no representations or 107 | warranties of any kind concerning the Work, express, implied, 108 | statutory or otherwise, including without limitation warranties of 109 | title, merchantability, fitness for a particular purpose, non 110 | infringement, or the absence of latent or other defects, accuracy, or 111 | the present or absence of errors, whether or not discoverable, all to 112 | the greatest extent permissible under applicable law. 113 | c. Affirmer disclaims responsibility for clearing rights of other persons 114 | that may apply to the Work or any use thereof, including without 115 | limitation any person's Copyright and Related Rights in the Work. 116 | Further, Affirmer disclaims responsibility for obtaining any necessary 117 | consents, permissions or other rights required for any use of the 118 | Work. 119 | d. Affirmer understands and acknowledges that Creative Commons is not a 120 | party to this document and has no duty or obligation with respect to 121 | this CC0 or use of the Work. 122 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # /r/Selfhosted Official Wiki 2 | 3 | This is the home of the full site source for the Hugo project that hosts the /r/selfhosted official wiki. 4 | 5 | ## Contributing 6 | 7 | You'll need to submit a pull request in order to submit content. If you just want to edit a typo or add a small correction to an existing document, feel free to edit it directly using the Github web-based edit function. Otherwise, refer to the local machine setup instructions below. 8 | 9 | ## Community 10 | 11 | Check out [/r/selfhosted](https://reddit.com/r/selfhosted) for the full details of what we represent and do. 12 | 13 | ## Local Machine Setup 14 | 15 | ### Installing Hugo 16 | 17 | Since we are using Hugo, getting your local site up and running is fairly simple. 18 | 19 | #### OS Independent 20 | 21 | Since Hugo is cross-platform, and OS choice is far from uniform in this community, I won't go into how to get Hugo functioning on your OS of choice. Follow the [Getting Started](https://gohugo.io/getting-started/quick-start/). It's not difficult. 22 | 23 | Once you can successfully get a version number from the command `hugo version`, you're ready to continue here. 24 | 25 | #### Fork and Clone Operations 26 | 27 | First thing you'll want to do is Fork the [Github Repository](https://github.com/r-selfhosted-wiki/wiki) for the /r/selfhosted wiki. You'll be working within a repo that syncs with your own accounts' fork of the repository. 28 | 29 | Since we use a theme that has its own [Github Repository](https://github.com/matcornic/hugo-theme-learn), there is an extra flag we must add to our `git clone` command. 30 | 31 | 1. First, clone the forked repo into your local machine. the "recurse-submodules" flag should allow you to automatically pull in the git repo for the theme, as well. 32 | 33 | `git clone --recurse-submodules https://github.com/{YOUR_USER_NAME}/wiki.git` -- Be sure to modify this url to match your actual username and git repository name. 34 | 35 | 2. Move to the directory that was just cloned and make sure the `themes/hugo-theme-learn/` folder has content. 36 | 37 | `cd wiki && ls themes/hugo-theme-learn` 38 | 39 | 3. Once confirmed, copy the example `config.toml` file. Unless you're doing some abstract hosting environment for your local developement machine, this should work as-is. 40 | 41 | `cp config.toml.example config.toml` 42 | 43 | 4. Run the server locally with the Hugo's server command 44 | 45 | `hugo serve` 46 | 47 | You should see some output about the success/launch of the local server, similar to below: 48 | 49 | ``` 50 | $ hugo serve 51 | Start building sites … 52 | 53 | | EN 54 | -------------------+----- 55 | Pages | 22 56 | Paginator pages | 0 57 | Non-page files | 0 58 | Static files | 75 59 | Processed images | 0 60 | Aliases | 0 61 | Sitemaps | 1 62 | Cleaned | 0 63 | 64 | Built in 84 ms 65 | Watching for changes in /home/kmisterk/wiki/{archetypes,content,data,layouts,static,themes} 66 | Watching for config changes in /home/kmisterk/wiki/config.toml 67 | Environment: "development" 68 | Serving pages from memory 69 | Running in Fast Render Mode. For full rebuilds on change: hugo server --disableFastRender 70 | Web Server is available at http://localhost:1313/ (bind address 127.0.0.1) 71 | Press Ctrl+C to stop 72 | ``` 73 | 74 | Navigate your browser to `http://localhost:1313` and you should see the site live on your local machine. 75 | 76 | You're now ready to start adding and/or editing content. 77 | -------------------------------------------------------------------------------- /archetypes/default.md: -------------------------------------------------------------------------------- 1 | --- 2 | title: "{{ replace .Name "-" " " | title }}" 3 | date: {{ .Date }} 4 | draft: true 5 | --- 6 | 7 | -------------------------------------------------------------------------------- /config.toml.example: -------------------------------------------------------------------------------- 1 | baseURL = "http://localhost/" 2 | languageCode = "en-US" 3 | title = "/r/SelfHosted Official Wiki" 4 | theme = "hugo-theme-learn" 5 | 6 | [params] 7 | themeVariant = "green" 8 | description = "The official wiki for the reddit /r/selfhosted community" 9 | titleSeparator = "| |" 10 | 11 | [outputs] 12 | home = [ "HTML", "RSS", "JSON"] 13 | 14 | [taxonomies] 15 | tag = "tags" 16 | category = "categories" 17 | -------------------------------------------------------------------------------- /content/Contribution/Adding a Page/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Adding a Page 3 | --- 4 | 5 | 6 | Adding pages with Hugo is easy! Each page has its own folder with an _index.md file. Make a new folder with an _index.md file inside. 7 | 8 | The _index.md file looks like this 9 | 10 | --- 11 | Title: TITLE HERE 12 | Other metafields: metafield content 13 | --- 14 | 15 | Content! 16 | 17 | See? It's easy! 18 | 19 | Page content uses Markdown syntax for text styles, formatting, hyperlinks, and all kinds of stuff. 20 | 21 | You can find more documentation about Markdown support in Hugo here: https://www.markdownguide.org/tools/hugo/ 22 | 23 | If you want more information on how to use Markdown syntax in content, please visit: https://daringfireball.net/projects/markdown/basics 24 | -------------------------------------------------------------------------------- /content/Contribution/File Structure/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: File Structure 3 | --- 4 | 5 | Hugo's file structure is simple. For example, here is the part of the file structure of this very wiki. 6 | 7 | / content 8 | _index.md 9 | 10 | / Contribution 11 | _index.md 12 | 13 | / Getting Started 14 | _index.md 15 | 16 | / Adding a Page 17 | _index.md 18 | 19 | / Guides 20 | _index.md 21 | 22 | / Webservers 23 | _index.md 24 | -------------------------------------------------------------------------------- /content/Contribution/Get Started/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Getting Started 3 | weight: 1 4 | --- 5 | 6 | This guide will show you how to setup a local environment for you to edit, create, or update content! 7 | 8 | Please note, if you wish to make a simple edit, you can always submit a quick pull request by utilizing the edit button on the file in question directly on the GitHub repo online. 9 | 10 | ## Installing Hugo 11 | 12 | Since we are using Hugo, getting your local site up and running is fairly simple. 13 | 14 | ### OS independent 15 | 16 | Since Hugo is cross-platform, and OS choice is far from uniform in this community, I won't go into how to get Hugo functioning on your OS of choice. Follow the [Getting Started](https://gohugo.io/getting-started/quick-start/). It's not difficult. 17 | 18 | Once you can successfully get a version number from the command `hugo version`, you're ready to continue here. 19 | 20 | ### Fork and clone operations 21 | 22 | First thing you'll want to do is to Fork the [GitHub Repository](https://github.com/r-selfhosted-wiki/wiki) for the /r/selfhosted wiki. You'll work within a repo that syncs with your own accounts' fork of the repository. 23 | 24 | Since we use a theme that has its own [GitHub Repository](https://github.com/matcornic/hugo-theme-learn), there is an extra flag we must add to our `git clone` command. 25 | 26 | 1. First, clone the forked repo into your local machine. The "recurse-submodules" flag should allow you to automatically pull in the git repo for the theme, as well. 27 | 28 | `git clone --recurse-submodules https://github.com/{YOUR_USER_NAME}/wiki.git` -- Be sure to modify this url to match your actual username and git repository name. 29 | 30 | 2. Move to the directory that has just been cloned and make sure the `themes/hugo-theme-learn/` folder has content. 31 | 32 | `cd wiki && ls themes/hugo-theme-learn` 33 | 34 | 3. Once confirmed, copy the example `config.toml` file. Unless you're doing some abstract hosting environment for your local development machine, this should work as-is. 35 | 36 | `cp config.toml.example config.toml` 37 | 38 | 4. Run the server locally with the Hugo's server command 39 | 40 | `hugo serve` 41 | 42 | You should see some output about the success/launch of the local server, similar to below: 43 | 44 | ``` 45 | $ hugo serve 46 | Start building sites … 47 | 48 | | EN 49 | -------------------+----- 50 | Pages | 22 51 | Paginator pages | 0 52 | Non-page files | 0 53 | Static files | 75 54 | Processed images | 0 55 | Aliases | 0 56 | Sitemaps | 1 57 | Cleaned | 0 58 | 59 | Built in 84 ms 60 | Watching for changes in /home/kmisterk/wiki/{archetypes,content,data,layouts,static,themes} 61 | Watching for config changes in /home/kmisterk/wiki/config.toml 62 | Environment: "development" 63 | Serving pages from memory 64 | Running in Fast Render Mode. For full rebuilds on change: hugo server --disableFastRender 65 | Web Server is available at http://localhost:1313/ (bind address 127.0.0.1) 66 | Press Ctrl+C to stop 67 | ``` 68 | 69 | 70 | Navigate your browser to `http://localhost:1313` and you should see the site live on your local machine. 71 | 72 | You're now ready to start adding and/or editing content. 73 | -------------------------------------------------------------------------------- /content/Contribution/Modify a Page/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Modify a Page 3 | --- 4 | 5 | Modifying a page is as simple as changing the _index.md file inside a folder. 6 | 7 | \ content 8 | _index.md <-- this here 9 | 10 | \ Subfolder 11 | _index.md <-- or this one 12 | 13 | \ Subfolder2 14 | _index.md <-- or even this one too 15 | 16 | Hugo uses Markdown to format and style text, among other things. 17 | 18 | You can find more information on how to use Markdown Syntax here: https://daringfireball.net/projects/markdown/basics 19 | -------------------------------------------------------------------------------- /content/Contribution/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Contribution Guidelines 3 | --- 4 | 5 | This guide aims to showcase how to contribute to this wiki, including best practices, pull requests, adding and editing articles and content, and file structure. 6 | -------------------------------------------------------------------------------- /content/Explanations/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Explanations 3 | --- 4 | 5 | ## Find explanations and definitions for common terms and concepts related to self-hosting 6 | 7 | ### Topics 8 | 9 | Explanations: 10 | 11 | - [Servers]({{}} "Servers") 12 | - [Daemons]({{}} "Daemons") 13 | - [Webservers]({{}} "Webservers") 14 | - [Domain names]({{}} "Domain names") 15 | - [DNS]({{}} "DNS") 16 | - [Reverse proxies]({{}} "Reverse proxies") 17 | - [Port forwarding]({{}} "Port forwarding") 18 | - [Containers]({{}} "Containers") 19 | - [Virtualization]({{}} "Virtualization") 20 | - [Virtual private networks]({{}} "Virtual private networks") 21 | - [Operating systems]({{}} "Operating systems") 22 | 23 | 24 | #### Servers 25 | 26 | Servers are machines whose purpose is to provide a service or content over a network. They are typically administered remotely and only connect physically to power and a network. They "serve" content or services using software daemons. 27 | 28 | Bare metal servers are not virtualized. Any service or content they offer is configured on the host system. They are not new *per-se*, but with the introduction of containerization and virtualization, the phrase has been coined to differentiate the old-school server tradition from newer techniques. 29 | 30 | Their natural habitat is the datacenter, where they live in racks to survive off electricity and network data. While they are not able to reproduce, they have no natural predators, so their population is stable. Some breeds of server can be found in network/data closets where they live in a business. Fewer are still kept in captivity in private homes. 31 | 32 | Virtual servers are servers that are run under an emulator or hypervisor to provide a server-like environment using a software envelope which may be augmented with hardware support. 33 | 34 | **[Top]({{}} "To the top")** 35 | 36 | ##### Daemons 37 | 38 | Daemons are software packages that run perpetually to provide content or a service. They differentiate servers from clients. 39 | 40 | Examples of daemons are webservers, email servers, file servers, authentication services (AD, LDAP), database servers, and many more. 41 | 42 | **[Top]({{}} "To the top")** 43 | 44 | #### Webservers 45 | 46 | Webservers are daemons that accept HTTP requests and serve set content based on the requested host (IP address or domain name). 47 | 48 | The content can be static HTML/XML or it can be dynamic (JavaScript, PHP, FCGI, WSGI). 49 | 50 | Webservers commonly offer reverse proxy functionality, it is common to use webservers for this purpose instead. 51 | 52 | Common webservers are: Apache, Cherokee, LiteSpeed, Lighttpd, nginx, and IIS. Apache and nginx are the top webservers by market share respectively, with IIS coming in third. 53 | 54 | **[Top]({{}} "To the top")** 55 | 56 | #### Domain names 57 | 58 | Domain names are a word, phrase, or string that is used for navigating the Internet. They are registered to individuals or legal entities in lengths of years for a set fee. 59 | 60 | They are divided into levels, where each level is separated by a period (dot). Domain registrations include the top-level and second-level portion of a domain. All levels below are controlled by DNS at the discretion of the domain registrant. 61 | 62 | Top-level domains (TLDs) are .com, .net, .info, .edu, .org, etc. 63 | 64 | The customizable part of the domain name you can register is called the second-level domain. 65 | 66 | Third-level domains are referred to as *subdomains*. 67 | 68 | Structure: subdomain.*secondleveldomain*.**tld** 69 | 70 | E.g.: wiki.*r-selfhosted*.**com** 71 | 72 | ##### Domain registration 73 | 74 | Registering a domain name is done with a *Domain Registrar*. Prices are based on the top-level domain, but all registrations are for a period of one year minimum. 75 | 76 | Registrars come in two flavors: 77 | 78 | - Accredited: These registrars work directly with ICANN or other regional Internet registries for domain registrations. 79 | - Domain Resellers: These companies work with a "white label" registrar to resell domain registrations for a small markup. 80 | 81 | Accreditation requires quite a bit of infrastructure and vetting to make sure you can handle all aspects of registering and maintaining domains on behalf of the registrant. 82 | 83 | Resellers are popular because of low overhead and easy implementation. Many "white label" registrars have turnkey solutions for resellers to appear as independent registrars while actually reselling domain names. 84 | 85 | ##### Which is right for you? 86 | 87 | Choosing a domain registrar is easy. Picking a domain registrar that is trustworthy and reputable is less so. 88 | 89 | Many domain registrars also offer to handle the DNS records for the domains registered with them. Many registrars have domain registration as a part of their business. Registration is usually bundled with webhosting or other related services. You may even get a domain registration for free if you agree to a year-long hosting contract with a webhost. 90 | 91 | While bundling related services together under one roof may sound convenient, it is generally not a good idea. It is recommended to have your domain registration with a registrar, DNS records with another company, and hosting with yet another entity. Common reasoning for this piece of advice is that if your service provider has a serious outage or other technical problem, it can only affect one aspect of your online presence. If you have all services under one provider, a technical issue could prevent your DNS from resolving and your website/service from being served. 92 | 93 | You can find the list of ICANN-accredited domain registrars here: https://www.icann.org/registrar-reports/accreditation-qualified-list.html 94 | 95 | As far as finding a reputable, trustworthy service provider, we must insist on your own research. One of the most popular forums for discussing hosting and related services is **[Web Hosting Talk](https://www.webhostingtalk.com/)**. If a relevant service provider has a bad reputation in the industry, you can surely find out about it here. 96 | 97 | **[Top]({{}} "To the top")** 98 | 99 | ##### Domain Name System 100 | 101 | The Domain Name System (DNS) is the method of defining what unique machines serve content for your domain. 102 | 103 | The important parts of DNS you have to worry about are *nameservers* and *DNS records*. 104 | 105 | ##### Nameservers 106 | 107 | Nameservers are a way to declare which servers are responsible for answering record requests for your domain. Most registrars provide DNS services, but if you have your DNS provided elsewhere, you will want to provide your primary and secondary nameservers to your registrar. The nameservers to use will be provided by your DNS service provider. 108 | 109 | E.g.: ns1.dnsnameserver.net, ns2.dnsnameserver.net 110 | 111 | ##### DNS records 112 | 113 | DNS records are part of your domain name configuration called a DNS *zone*. 114 | 115 | **SOA**: Start of Authority Records is generally handled by your DNS service provider automatically. They define: 116 | - **MNAME**: Master nameserver for the zone. 117 | - **RNAME**: Email for the domain administrator. Does not support "@", use periods. Periods before the domain name are escaped. E.g.: some.one@example.com => "some\\.one.example.com". 118 | - **SERIAL**: The DNS zone **serial**, used to indicate when a zone has changed. 119 | - **REFRESH**: Time to wait for secondary nameservers to query the master. 120 | - **RETRY**: Timeout for refreshing. 121 | - **EXPIRE** Threshold time for secondary nameservers to stop attempting to reach an unresponsive master server. 122 | - **TTL**: The time to live to use for NXDOMAIN responses. 123 | 124 | **Example SOA**: 125 | 126 | ``` 127 | $TTL 86400 128 | @ IN SOA ns1.nameserver.com. postmaster.sumdomain.com. ( 129 | 2020080302 ;Serial 130 | 7200 ;Refresh 131 | 3600 ;Retry 132 | 1209600 ;Expire 133 | 3600 ;Negative response caching TTL 134 | ) 135 | ``` 136 | 137 | The fields of a DNS zone record are: 138 | 139 | - Domain: Either the domain name or subdomain to create a record for. 140 | - Time to live: The time in seconds for a record to be cached before a new copy is requested. 141 | - Class: Indicative of the namespace. Usually IN (Internet namespace). 142 | - Type: The type of record to define. 143 | - Content: The content of the record. What is acceptable in this field is dependent on the type of record. 144 | 145 | There are many types of DNS records, let's go over some common ones. This list is **not** exhaustive. 146 | 147 | - A: A records tie the domain or subdomain to an IPv4 address. 148 | - AAAA: AAAA records tie the domain or subdomain to an IPv6 address. 149 | - CNAME: CNAME records tie the domain or subdomain to another domain or subdomain. 150 | - MX: MX records are used to define how mail is handled for your domain. The content of an MX record is the priority and answering server domain name. Lower preference number indicates higher priority. 151 | - TXT: Text records associate text data with your domain. They are used for a variety of reasons, notable for SPF or DKIM. 152 | 153 | | Domain | Time To Live | Class | Type | Content | 154 | |--------|--------------|----|------|---------| 155 | | example.com. | 86400 | IN | A | 192.168.1.240 | 156 | | ipv6.example.com. | 86400 | IN | AAAA | feef:00bb:2005:1eef:fbca:544d | 157 | | www.example.com. | 86400 | IN | CNAME | example.com. | 158 | | example.com. | 86400 | IN | MX | 10 mail.mailserver.com | 159 | | example.com. | 86400 | IN | TXT | "Reserved for a purpose I am not legally required to disclose." | 160 | 161 | **[Top]({{}} "To the top")** 162 | 163 | #### Reverse proxies 164 | 165 | Reverse proxies are daemons that accept connections and then connect to another service based on port or host to facilitate the request. They act as a middleman instead of a traffic redirector. 166 | 167 | Typical use cases for reverse proxies are to provide a unified frontend for multiple backends or hosts. Another common use is for high-availability to provide failover or distribute load between multiple backends serving the same content. 168 | 169 | Examples of popular software capable of performing as a reverse proxy are: Squid, HAProxy, Apache, nginx, and Caddy. 170 | 171 | **[Top]({{}} "To the top")** 172 | 173 | #### Port forwarding 174 | 175 | Port forwarding is the function of inspecting traffic on an incoming port and redirecting it to another port or host with minimal modification. Primary purposes of this are to forward traffic to a service behind a firewall/router. 176 | 177 | Common for hosting game servers from home when running dedicated servers before developers moved to match-making. Another use for this is to open ports for BitTorrent so that you can share your vast and innumerable collection of Linux ISOs. 178 | 179 | The difference between port forwarding and a reverse proxy is that the reverse proxy will accept, process, and establish a new connection to the backend service to fulfil the request. 180 | 181 | Port forwarding inspects and alters packet headers before it is routed to its new destination. The connection is otherwise untouched. 182 | 183 | Port forwarding is a function of your firewall. Commonly at the router or other network gateway. 184 | 185 | Linux has one firewall called **iptables** with many frontends or management packages available for it. BSD-based firewalls are **pf**, **ipfw**, and **IPFilter**. The Windows firewall consists of a scarecrow holding a sign saying: "plz no tresspass". 186 | 187 | **[Top]({{}} "To the top")** 188 | 189 | #### Containers 190 | 191 | Containers are software envelopes to isolate a piece or bundle of software and their dependencies. Containers come in many forms. 192 | 193 | A container could contain a PHP-based forum with an AMP stack (Apache, Maria DB, PHP) as dependencies. 194 | 195 | This is useful if you want an easy way to deploy software without configuring dependent software/libraries manually. 196 | 197 | Containers can also resolve software conflicts when running multiple services which depend on different versions of the same software/libraries. 198 | 199 | Popular containers are Linux Containers (LXC), jails (BSD UNIX), Kubernetes, and Docker. 200 | 201 | **[Top]({{}} "To the top")** 202 | 203 | #### Virtualization 204 | 205 | Virtualization is a lower level form of containerization. There are many forms of virtualization that provide different sets of features/tradeoffs. 206 | 207 | In practice, it often virtualizes whole or major parts of an operating system. 208 | 209 | ##### Full virtualization 210 | 211 | Full virtualization is generally the containerization of a full, unmodified operating system with virtualized hardware. The virtualized OS is not host-aware. 212 | 213 | Fully virtualized guests require more overhead than paravirtualized guests. This can be mitigated with hardware support (Intel VT, AMD SVM) for virtualization instructions. 214 | 215 | Examples of this are Hyper-V, Xen, KVM/Qemu, VMware ESXi. 216 | 217 | ##### Paravirtualization 218 | 219 | Paravirtualization is the practice of running a modified kernel/OS where privileged instructions are sent through an API shared with the host. It does not require the virtualization of hardware, but it does require an operating system that is modified to be used with the specific API used by your chosen virtualization method. This can be in the form of source code modifications or specialized device drivers. 220 | 221 | Microsoft Windows cannot be paravirtualized. 222 | 223 | Examples: Xen, Oracle VM, OpenVZ. 224 | 225 | **[Top]({{}} "To the top")** 226 | 227 | #### Virtual private networks 228 | 229 | Virtual private networks (VPNs) are a way of networking individual machines together in software regardless of their physical or network proximity. 230 | 231 | A typical use case is for networking corporate locations together to share network resources such as file shares, intranet webservers, on-premises services, etc. 232 | 233 | Another use for a VPN is to tunnel traffic destined for a public service through to another endpoint, usually to bypass geo-location restrictions or state-imposed censorship of the Internet. 234 | 235 | Some use VPNs to keep services behind a restrictive ISP or firewall accessible outside of said network. 236 | 237 | **[Top]({{}} "To the top")** 238 | 239 | #### Operating systems 240 | 241 | An operating system is the software that is responsible for running and managing your physical machine. It provides the kernel, hardware drivers, low-level software packages, libraries, and userland applications for the end-user to provide basic functions. 242 | 243 | End-user operating system for desktop computers or laptops is typically Windows. 244 | 245 | Corporate IT infrastructure to serve employees is generally Microsoft-based additionally using AD for authentication, on-premises exchange, IIS webservers, MS SQL databases, and other service needs. 246 | 247 | The operating system used to serve content and services to end-customers is typically Linux or UNIX-based. Examples are webhosts for serving websites, Netflix for serving movie and TV streams, DNS services for domain records, and most if not all other infrastructure needed to keep the Internet operational. 248 | 249 | Android is a Linux-based operating system used in the majority of the smartphone market. And iOS is a UNIX-based mobile OS used by Apple for iPhones. 250 | 251 | Embedded Linux and BSD are also used in devices like set-top boxes, smart TVs, routers, smart switches, medical equipment, flight telemetry controllers for aerospace, navigation equipment, industrial automation, etc. 252 | 253 | **[Top]({{}} "To the top")** 254 | -------------------------------------------------------------------------------- /content/Getting Started/Difficulty Tiers/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Difficulty Tiers 3 | tags: [easy, normal, hard] 4 | --- 5 | 6 | ### How hard *is* stuff? 7 | 8 | Stuff can be hard. Stuff can also be easy. Some things here are hard. Some things are easy. Let's define some difficulty tiers. 9 | 10 | ### Easy / Basic 11 | 12 | No worries here, folks! Everything should be done with a GUI with *maybe* some stuff needing a command or two, or maybe just editing some text files. Instructions should come in picture form. 13 | 14 | Operating systems in this tier are Ubuntu Linux, Windows, or OS X. 15 | 16 | ### Normal / Intermediate 17 | 18 | Still not hard, but you're expected to know how not to break things in a terminal or text-based interface. GUI is optional, but used on occasion. 19 | 20 | Operating systems in this tier are Debian Linux, Red Hat Enterprise Linux, Rocky Linux. 21 | 22 | ### Hard / Advanced 23 | 24 | You are at home with a terminal and all things can be accomplished with it. You know how not to break a system with a terminal, but also how to fix serious system-level issues. 25 | 26 | Operating systems in this tier are Arch, *BSD, Slackware Linux, Gentoo Linux. 27 | 28 | ### Guru / Expert 29 | 30 | You compile your software from source and surf the web with Lynx. If you don't know what that means you are a *poser*. 31 | 32 | You run [Suicide Linux](https://qntm.org/suicide) because anything less is for little babies. 33 | -------------------------------------------------------------------------------- /content/Getting Started/How To Self Host/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: How to Self-Host 3 | --- 4 | 5 | Here we will go over the basics of what self-hosting entails. There will be a lack of detail in each individual step as those details are reserved for their own documentation in a separate article or are specific to a provider/service as not everything can be self-hosted, especially if you wish to make a service publicly available. 6 | 7 | ### Contents 8 | 9 | - [Choosing a server]({{}} "Choosing a Server") 10 | - [Domain name registration]({{}} "Registering a Domain Name") 11 | - [DNS configuration]({{}} "Domain Name Records") 12 | - [Network configuration]({{}} "Network Configuration") 13 | - [Server setup]({{}} "Server Configuration") 14 | 15 | #### Choosing a server 16 | 17 | A server can be just about anything. An old computer that you don't use anymore, a cheap small form factor machine from an online store, a custom built machine using server grade or consumer parts, or even a Raspberry Pi which can be gotten for under $100. 18 | 19 | An operating system to install to make it a server is another choice you have to make. Windows Server is usually not chosen due to licensing costs, but it is an option. Linux comes in many flavors to meet many needs. It is freely available and free to modify. 20 | 21 | **[To the top]({{}} "Top")** 22 | 23 | #### Registering a domain name 24 | 25 | Registering a [domain name]({{}} "domain name") is usually the first step when you are looking to have something self-hosted that is reachable via the Internet. Although you can even find a free domain name, it is always a good idea to find a domain registrar you can trust; recommending specific providers is outside the scope of this wiki. 26 | 27 | Top-level domain names vary in price. Dot.com domain names are usually ~$15/yr, while others like dot.net or dot.info are typically less. Some can be more expensive, and the registrar will have their price listings based on the top-level domain. Domain registration is a competitive business, with lots of resellers working for white-label registrars. You can look at several registrars to compare prices for the domain you want to register. In some cases you may choose a free domain name, e.g. under .TK, .ML, .GA, .CF, or .GQ, but be ready that most search engines would range your site much worse, so such solution is not recommended for serious projects. 28 | 29 | Domain registrations are on a first-come, first-serve basis. If the domain name you want is already taken, you will have to wait until it expires, or buy it from the current owner. Otherwise, you can come up with a different domain name to register. 30 | 31 | **BEWARE**: Some domain registrars will take domain names that you search for, but not purchase, and "hold" their registration. 32 | 33 | E.g.: You go to someregistrar.com and search for ilikeponies.com to see if it's available for registration. You find that it is available, but want to check out someotherregistrar.com to see their prices for the same domain. When you check there, the domain ilikeponies.com is taken. But when you search for it again on someregistrar.com, it's still available. 34 | 35 | What is happening is that someregistrar.com has "held" the registration for a period of time to prevent you from registering it elsewhere in hopes that you take your business with them. 36 | 37 | While we are not certain of the legality of such practice, it is considered uncouth and frowned upon in the industry. You can resolve this by contacting the registrar, telling them they are massive jerks, and have them release the hold. 38 | 39 | If they have no shame, you may have to explain that your poor experience with them can wind up on webhostingtalk.com for the world to see. 40 | 41 | **[To the top]({{}} "Top")** 42 | 43 | #### Domain name records 44 | 45 | Once you have registered a domain name, you will need to configure the nameservers and then add [DNS records]({{}} "DNS records") for the domain that points to the IP address of your server. 46 | 47 | Your domain registrar makes use of the nameserver records, and your DNS provider will take care of the other types of records. 48 | 49 | The basic DNS records to add are an A record for yourdomainname.com, and a CNAME for www.yourdomainname.com. 50 | 51 | Get the IP address of the machine you will use. If you serve locally, then the local IP address of the machine will not work (e.g.: 192.168.1.X). You will have to use your public IP and use a reverse proxy + VPN or port forward. You can find your public IP address on your router status page or by going to https://ifconfig.me/. 52 | 53 | Use that IP as the content for your DNS A record. 54 | 55 | See your router documentation for directions on setting up port forwarding to the machine's local IP address. 56 | 57 | **[To the top]({{}} "Top")** 58 | 59 | #### Network configuration 60 | 61 | Your ISP is likely to block common ports used for Internet traffic such as 80 (HTTP), 443 (HTTPS), 21 (FTP), 25 (email SMTP), and many others. 62 | 63 | Some ISPs will have no problem unblocking some of these ports, but don't expect them to cooperate. 64 | 65 | Regardless, there are options to get around these issues if your ISP is non-cooperative. There may be clauses in your service agreement stating that hosting services from your home Internet connection is prohibited. While ISPs rarely take action against customers if they are found in violation of this rule, there are legitimate reasons for having such clause. 66 | 67 | Generally if you bypass their restrictions to self-host anyway, they don't care unless you cause problems for them. 68 | 69 | If you have a business Internet plan, these issues don't exist. You may still have to request a static IP, but your ISP should not be blocking ports by default as it is assumed you will be handling that yourself. If they are, they should cooperate with any unblocking requests. 70 | 71 | The typical way to bypass these restrictions is either to port forward (if your ISP doesn't block the ports) or using a reverse proxy in conjunction with a VPN using an Internet-reachable machine. 72 | 73 | You also have to contend with dynamic IP addresses. Your home connection is assigned to a public IP address, but it is not fixed, and can change if your DHCP lease on their network expires. Some ISPs may offer to provide you a static IP address for a monthly fee. 74 | 75 | For dynamic IP addresses, your DNS provider may support dynamic DNS updates. This can either require a dedicated client, or to simply call a URL with an embedded token with a program like Wget or cURL. It is an effective way to have a DNS record automatically updated on a regular basis to counteract a changing IP address. 76 | 77 | **[To the top]({{}} "Top")** 78 | 79 | #### Server configuration 80 | 81 | You need a server to handle requests for your domain name. This can be a shared hosting account with a web hosting provider, a dedicated server, a virtual private server, or your own server running locally. 82 | 83 | Despite the fact that you might find providers that could serve you some limited server storage and computing power remotely even for free, this is a self-hosting guide, so the assumption that the server is local has been made. 84 | 85 | Once you have chosen and installed the operating system you are going to use, you will need to setup your service daemon. For the sake of this article, we will assume that you'd like to serve a website using your domain name. 86 | 87 | There are a variety of web servers available, and the specific details on configuring that web server will be covered elsewhere. 88 | The basic steps are: 89 | 90 | - install the web server 91 | - configure it to answer for your domain name 92 | - give it a directory to serve from (/some/directory/domainname.com/html) 93 | - upload content into that folder 94 | 95 | Make sure the content folder has the permissions needed by your web server, and you should be good to go. 96 | 97 | This same process is generally the same for any service, but the documentation for said service should be consulted. 98 | 99 | **[To the top]({{}} "Top")** 100 | -------------------------------------------------------------------------------- /content/Getting Started/Operating Systems/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Operating Systems 3 | --- 4 | 5 | There are many operating systems available to meet different needs. Some are more difficult to administer than others, but there should be a solution available for whatever you want to do. 6 | 7 | While paying for a licensed product is always an option if you find the value in said product worth the cost, it is recommended to make sure that a "free" solution could not meet the same needs. 8 | 9 | #### Proprietary / Licensed 10 | 11 | - [Microsoft Windows Server](https://www.microsoft.com/en-us/windows-server/) | Windows is not usually chosen due to licensing costs. 12 | - [Unraid](https://unraid.net/) | Linux-based, but requires the purchase of a license for usage past the trial period. 13 | 14 | #### Entry Level / Easy 15 | 16 | These are operating systems that are administered with a GUI/web-based frontend to focus on ease of use. 17 | 18 | - [YunoHost](https://yunohost.org) | [Demo](https://yunohost.org/#/try) 19 | - [TrueNAS CORE](https://www.truenas.com/truenas-core/) | A FreeBSD-based NAS operating system with ZFS support. Published by [iXsystems](https://www.ixsystems.com/), [TrueNAS and FreeNAS were "Unified" in late 2021](https://www.ixsystems.com/history/). 20 | - [TrueNAS SCALE](https://www.truenas.com/truenas-scale/) | A Debian Linux NAS operating system. Published by iXsystems, and based around work done for TrueNAS CORE. 21 | - [OpenMediaVault](https://www.openmediavault.org/) 22 | - [DietPi](https://dietpi.com/) | Built for single-board computers like Raspberry Pi or Pine64 boards. 23 | - [Sandstorm](https://sandstorm.io/) | [Demo](https://alpha.sandstorm.io/apps) 24 | 25 | #### Intermediate / Headless 26 | 27 | If you are comfortable managing your server using terminal, then these options will work for you. They do a lot of hard work for you and should be simple to administer when needed. 28 | 29 | - [Ubuntu Server](https://ubuntu.com/server) | Debian-based server OS developed by Canonical Ltd. 30 | - [Rocky Linux](https://rockylinux.org/) | Fork/replacement for CentOS. 31 | - [openSUSE](https://www.opensuse.org/) 32 | - [Fedora Linux](https://getfedora.org/en/server/) 33 | - [Debian](https://www.debian.org/) | One of the two oldest Linux distributions that are still maintained. Stable, mature, and proven. 34 | 35 | #### Advanced 36 | 37 | - [Arch Linux](https://archlinux.org/) | A light, simple distribution that provides a small foundation to build on. Rich documentation and a large community-maintained third party software repository make it a solid choice for Linux veterans. Tailored for experienced users. 38 | - [Gentoo Linux](https://www.gentoo.org/) | A Linux distribution focused on building packages from source to best fit your system. Binary packages are available, but that's like, against the spirit duuude. 39 | - [Slackware Linux](http://www.slackware.com/) | The other of the two oldest Linux distributions that are still maintained today, it focuses on stability and sticking to its UNIX roots. 40 | - [FreeBSD](https://www.freebsd.org/) | Almost as old as Linux itself, it is derived from BSD UNIX as developed at the University of California in Berkley. Used by Netflix as the OS powering its digital media delivery nodes. 41 | - [Alpine Linux](https://alpinelinux.org/) | A tiny Linux distribution catering to power users who want to squeeze the most resources out of their systems. 42 | 43 | #### Niche / Other 44 | 45 | - [Proxmox VE](https://www.proxmox.com/en/proxmox-ve) | An operating system focused on the management of a virtualization environment utilizing KVM as a hypervisor. 46 | - [XCP-ng](https://xcp-ng.org/) | XenServer-based, offers a turnkey virtualization solution. 47 | -------------------------------------------------------------------------------- /content/Getting Started/Reverse Proxies/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Intro to Reverse Proxies 3 | --- 4 | 5 | ### **Reverse proxies and YOU** 6 | 7 | What can a reverse proxy do for *you*? 8 | 9 | Many services that are self-hosted have a web UI. If you have many of these services running, a reverse proxy can be a central daemon that handles requests for all of these various backends. 10 | 11 | Let's say that you have three different services running: 12 | 13 | - Node.js forum NodeBB that runs on port 8008 14 | - Navidrome music streaming server on port 3000 through a local machine using IP 192.168.1.125 15 | - ownCloud web UI on port 8800 on a local machine with an IP of 192.168.1.123 16 | 17 | You have a domain name that you want to use for these but don't want an ugly URL like http://mydomain.com:8008. To complicate things further, these services are all on different hosts. 18 | 19 | A reverse proxy can be configured to accept requests for this domain and redirect them to a different host or port. 20 | 21 | To make your URLs pretty, the reverse proxy can be configured to redirect requests on your domain based on a folder name to a different service on your local network. 22 | 23 | - http://mydomain.com/forum/ --> http://localhost:8008/ 24 | - http://mydomain.com/music/ --> http://192.168.1.125:3000/ 25 | - http://mydomain.com/cloud/ --> http://192.168.1.123:8800/ 26 | 27 | As you can see, it is much nicer to reach these services through a single domain and folder than to use their port and host individually. 28 | 29 | You can even couple this with a self-hosted VPN so that these requests can be proxied to different services on different networks in different locations. All you need to do is to make sure the proxy and the services are on the same VPN and to use the VPN IP addresses. 30 | 31 | You don't have to use folders either. You can use subdomains as well such as music.mydomain.com, cloud.mydomain.com, and forum.mydomain.com respectively. It's all up to you and how you want to structure your services. 32 | -------------------------------------------------------------------------------- /content/Getting Started/Self-Hosted Alternatives/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Self-Hosted Alternatives 3 | --- 4 | 5 | ### ALTERNATIVE STUFF HERE 6 | 7 | There will be some common choices in some common categories here for some self-hosted alternatives. A more comprehensive list of alternatives will be listed at the bottom of this page. 8 | 9 | **None of the software listed on this page is endorsed or supported by r/selfhosted.** 10 | 11 | #### Webservers 12 | 13 | Daemons that serve website content. 14 | 15 | - [Apache](https://httpd.apache.org/) | The most popular webserver since forever. Higher overhead than others, but most PHP applications assume it. 16 | - [nginx](https://www.nginx.com/) | Second most popular webserver today, created to run some of the biggest Russian websites. 17 | - [Lighttpd](https://www.lighttpd.net/) | A more niche webserver focusing on low overhead and high performance. 18 | - [Caddy](https://caddyserver.com/) | A fast, multi-platform web server with automatic HTTPS. 19 | 20 | #### Databases 21 | 22 | Daemons or services that store data in a structured format. 23 | 24 | - [PostgreSQL](https://www.postgresql.org/) | A popular database solution that emphasizes extensibility and standards compliance. 25 | - [Maria DB](https://mariadb.org/) | Based on MySQL, forked to maintain an open source alternative that is mostly compatible with MySQL-based applications. 26 | - [MongoDB](https://www.mongodb.com/) | A document-based NoSQL database that uses JSON-like formatting to store information. 27 | - [SQLite](https://www.sqlite.org/index.html) | Flat file database that doesn't require a running DB server. 28 | 29 | #### Content management systems 30 | 31 | Frontends for managing the content on your website. 32 | 33 | - [WordPress](https://wordpress.org/) | The most popular CMS by market share, uses the blog format. 34 | - [Joomla!](https://www.joomla.org/) | Another popular CMS written in PHP. 35 | - [WonderCMS](https://www.wondercms.com/) | Claims to be the smallest CMS around. Is definitely small. 36 | 37 | #### E-commerce 38 | 39 | Software for operating and managing an e-shop. 40 | 41 | - [OpenCart](https://www.opencart.com/) 42 | - [Magento](https://magento.com/) 43 | - [PrestaShop](https://www.prestashop.com/en) 44 | 45 | #### File synchronization 46 | 47 | Services that synchronize files across systems. 48 | 49 | - [ownCloud](https://owncloud.com/) 50 | - [Syncthing](https://syncthing.net/) 51 | - [Seafile](https://www.seafile.com/en/home/) 52 | 53 | #### Media streaming 54 | 55 | Daemons for streaming digital media. 56 | 57 | - [Jellyfin](https://jellyfin.org/) | Media streaming server capable of handling audio, video, comics, books, and photos. 58 | - [Icecast](https://www.icecast.org/) | Operate your own Internet radio station! 59 | - [Navidrome](https://www.navidrome.org/) | Music streaming software with a web UI and compatible with Subsonic/Airsonic clients. 60 | 61 | #### Photo galleries 62 | 63 | Software for operating a photo gallery. 64 | 65 | - [Chevereto](https://chevereto.com/free) 66 | - [Zenphoto](http://www.zenphoto.org/) 67 | - [Piwigo](http://piwigo.org/) 68 | 69 | #### Wiki software 70 | 71 | You own personal knowledge base! 72 | 73 | - [DokuWiki](https://www.dokuwiki.org/DokuWiki) | A simple wiki that stores content in text files instead of a database. 74 | - [MediaWiki](https://www.mediawiki.org/wiki/MediaWiki) | The software that powers [Wikipedia](https://wikipedia.org). 75 | - [Cowyo](https://github.com/schollz/cowyo) | A minimal wiki/note-taking package. 76 | 77 | ----- 78 | 79 | The master lists of self-hosted alternatives. 80 | 81 | - [Self-Hosted Alternatives](https://github.com/awesome-selfhosted/awesome-selfhosted) | Master List for self-hosted alternative software packages. 82 | - [Self-Hosted Sysadmin](https://github.com/n1trux/awesome-sysadmin) | Similar to the above, but oriented towards the needs of system administrators or IT professionals. 83 | -------------------------------------------------------------------------------- /content/Getting Started/What Is Self-Hosting/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: What is Self-Hosting? 3 | --- 4 | 5 | **The act of providing or serving digital content or an online service typically delivered by a business.** 6 | 7 | It is generally served locally, as hosting it on a VPS or other Internet-residing machine is not "hosting" it yourself. There is still a middleman, and that is the owner/operator of that Internet-residing machine. 8 | 9 | --- 10 | 11 | One of the easiest things to self-host with the lowest barrier to entry is a website. For the most basic website of your own, all you need is a domain name and a webserver. Then you throw a few lines of HTML in a file and you have yourself a "website". With a service like Let's Encrypt, securing the site with a SSL certificate is easy too. 12 | 13 | A lot of different services that you can self-host are "websites". There are dynamic sites with robust content management systems like Joomla!, Drupal, WordPress, or b2evolution. There are forums like phpBB, MyBB, vBulletin, Discourse, etc. Knowledge bases like DokuWiki, MediaWiki, BookStack, or Gollum are also websites. These websites only require a webserver, an interpreter (PHP), and a database (SQLite, PostgreSQL, MySQL). 14 | 15 | Just about everything these days has a web UI or frontend to make things easier. HTTP/HTML/JS are well-understood standards that are ubiquitous. There are many libraries for converting or presenting your content in a web-friendly way for almost all programming languages you can learn. 16 | 17 | It can be hard for someone unfamiliar to find the difference between the "website" frontend and the content backend. Sometimes the difference is almost non-existent. Sometimes there are many layers and systems working behind the scenes to make it happen. 18 | 19 | It may be better to say that everything can be "accessed" through a website, even if it isn't one *per-se*. And if it can't, there's probably a separate piece of software that makes a web UI for it. 20 | 21 | Examples of services with a web UI or separate web-based frontends are: BitTorrent clients like qBittorrent/Transmission, media streaming servers like Jellyfin/Navidrome, file synchronization services like Nextcloud/ownCloud/Seafile, communication services like Synapse/InspIRCd/jabberd/Mumble, and many more. 22 | 23 | Other services use the server-client model where the entire package is in two parts. The server part that runs at all time to serve content and the client part that connects to have content served to it. Examples are: game servers like Rust/Minecraft/Factorio, FTP servers, email servers, and more. 24 | -------------------------------------------------------------------------------- /content/Getting Started/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Getting Started 3 | --- 4 | 5 | Here are some explanations for the basics and themes of Self-Hosted. 6 | 7 | - [Difficulty tiers]({{}} "Difficulty tiers") 8 | - [How do I self-host?]({{}} "Self-hosted how-to") 9 | - [Intro to reverse proxies]({{}} "Intro to reverse proxies") 10 | - [Operating systems]({{}} "Operating systems") 11 | - [What are some self-hosted alternatives to stuff I use every day?]({{}} "Self-hosted alternatives") 12 | - [What is self-hosting?]({{}} "What is self-hosting?") 13 | -------------------------------------------------------------------------------- /content/Guides/DevOps Toolchains/Gitlab Kubernetes/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Gitlab Installation 3 | tags: [normal] 4 | --- 5 | ___ 6 | 7 | ## Introduction 8 | 9 | In this article, I will describe all the steps required to setup GitLab CI/CD in kuberntes using kustomize. 10 | We will go through how to run GitLab on Kubernetes when you have related resources `postgres`, `redis`, `minio`, `tls certificates` etc already available in your setup. 11 | 12 | This is a very common scenario in companies and also for self-hosting that you are already using these services in your environment and prefer to use the same for gitlab. 13 | 14 | 15 | *The all in one production installation may be easily performed with Helm. You can refer to official documentation from gitlab if that is your requirement.* 16 | 17 | 18 | ### Requirements 19 | 20 | You will need the following in order to run gitlab. 21 | 22 | 1. Database : Postgres database is required for gitlab. 23 | 2. Cache : Redis is used for caching. 24 | 3. Storage : Minio is used as object storage for `container registry`, `gitlab backups`, `terraform storage backend`, `gitlab artifacts` etc. 25 | 4. Ingress Controller : Nginx ingress is part of installation. 26 | 5. Persistent Volume : Gitaly will store `repository data` data on disk, for that your kubernetes cluster must have a way of provisioning storage. You can install [local path provisioner](https://github.com/rancher/local-path-provisioner) in your cluster for dynamically provisioning volumes. 27 | 28 | * Repositories 29 | 1. [Gitlab Manifests](https://github.com/kha7iq/gitlab-k8s) 30 | 2. [SubVars App](https://github.com/kha7iq/subvars) 31 | 32 | *Info: You can swap minio with any other object storage i.e S3 by changing connection info secret* 33 | 34 | ## Lets get Started 35 | 36 | When installing gitlab with helm it generates the configmaps after rendering the templates with parameters, we can manually change these values in configmaps but its a hassle and not convenient. 37 | 38 | To make this process easy we will use a tool called [subvars](https://github.com/kha7iq/subvars) which will let us render these values from command line. Install it by following the instructions on [github](https://github.com/kha7iq/subvars) page, we will use it later. 39 | 40 | 41 | 1. Download the release with manifests from [github](https://github.com/kha7iq/gitlab-k8s) alternatively you can clone the repo, if you are cloning the repo remove the `.git` folder afterwards as it creates issues some times when rendering multiple version of the same file with subvars. 42 | 43 | ```bash 44 | export RELEASE_VER=1.0 45 | wget -q https://github.com/kha7iq/gitlab-k8s/archive/refs/tags/v${RELEASE_VER}.tar.gz 46 | tar -xf v${RELEASE_VER}.tar.gz 47 | cd gitlab-k8s-${RELEASE_VER} 48 | ``` 49 | 50 | 51 | 2. Lets start by setting the url for gitlab in our [kustomization file](https://github.com/kha7iq/gitlab-k8s/blob/master/ingress-nginx/kustomization.yaml) within ingress-nginx folder. You will find two blocks, one for web-ui and second for registry along with tls-secret-name for https. 52 | 53 | ```yaml 54 | patch: |- 55 | - op: replace 56 | path: /spec/rules/0/host 57 | value: your-gitlab-url.example.com 58 | - op: replace 59 | path: /spec/tls/0/hosts/0 60 | value: your-gitlab-url.example.com 61 | - op: replace 62 | path: /spec/tls/0/secretName 63 | value: example-com-wildcard-secret 64 | ``` 65 | 66 | 3. We can create `minio-conn-secret` containing configuration for minio. It will be used for all the enabled S3 buckets except gitlab backups, we will create that separately. Input the information as per your setup and create the kubernetes secret. 67 | 68 | * minio.config 69 | ```bash 70 | cat << EOF > minio.config 71 | provider: AWS 72 | region: us-east-1 73 | aws_access_key_id: 4wsd6c468c0974006d 74 | aws_secret_access_key: 5d5e6c468c0974006cdb41bc4ac2ba0d 75 | aws_signature_version: 4 76 | host: minio.example.com 77 | endpoint: "https://minio.example.com" 78 | path_style: true 79 | EOF 80 | ``` 81 | * Kubernetes secret 82 | ```bash 83 | kubectl create secret generic minio-conn-secret \ 84 | --from-file=connection=minio.config --dry-run=client -o yaml >minio-connection-secret.yml 85 | ``` 86 | 87 | 4. Next step is to create a secret with mino configuration for gitlab backup storage. Just replace minio endpoint, bucket name, access key & secret key. 88 | 89 | ```bash 90 | cat << EOF > storage.config 91 | [default] 92 | access_key = be59435b326e8b0eaa 93 | secret_key = 6e0a10bd2253910e1657a21fd1690088 94 | bucket_location = us-east-1 95 | host_base = https://minio.example.com 96 | host_bucket = https://minio.example.com/gitlab-backups 97 | use_https = True 98 | default_mime_type = binary/octet-stream 99 | enable_multipart = True 100 | multipart_max_chunks = 10000 101 | multipart_chunk_size_mb = 128 102 | recursive = True 103 | recv_chunk = 65536 104 | send_chunk = 65536 105 | server_side_encryption = False 106 | signature_v2 = True 107 | socket_timeout = 300 108 | use_mime_magic = False 109 | verbosity = WARNING 110 | website_endpoint = https://minio.example.com 111 | EOF 112 | ``` 113 | 114 | ```bash 115 | kubectl create secret generic storage-config --from-file=config=storage.config \ 116 | --dry-run=client -o yaml > secrets/storage-config.yml 117 | ``` 118 | 119 | > All other secrets can be used as is from repository or you can change all of them following [gitlab documentation](https://docs.gitlab.com/charts/installation/secrets.html) 120 | 121 | 5. One of the most important secret is `gitlab-rails-secret`, in case of a disaster where you have to restore gitlab from a backup you must apply the same secret in your cluster as these keys will be used to decrypt the database etc from backup. Make sure you keep this consistent after first install. 122 | 123 | 124 | 6. We reached the last part, Its alot of work to change database and other parameters one by one in configmaps. 125 | I have implemented some templating for this which can provide all the values vi environment variables and render the manifests with subvars, it will output these to destination folder and replace all the parameters defined as go templates. 126 | The values are self explanatory, `GITLAB_GITALY_STORAGE_SIZE` variable is used to specify how much storage is needed for gitaly and `GITLAB_STORAGE_CLASS` is the name of storage class. 127 | 128 | ```bash 129 | GITLAB_URL=gitlab.example.com \ 130 | GITLAB_REGISTRY_URL=registry.example.com \ 131 | GITLAB_PAGES_URL=pages.example.com \ 132 | GITLAB_POSTGRES_HOST=192.168.1.90 \ 133 | GITLAB_POSTGRES_PORT=5432 \ 134 | GITLAB_POSTGRES_USER=gitlab \ 135 | GITLAB_POSTGRES_DB_NAME=gitlabhq_production \ 136 | GITLAB_REDIS_HOST=192.168.1.91:6379 \ 137 | GITLAB_GITALY_STORAGE_SIZE=15Gi \ 138 | GITLAB_STORAGE_CLASS=local-path \ 139 | subvars dir --input gitlab-k8s-1.0 --out dirName 140 | ``` 141 | Change into `dirName/gitlab-k8s-1.0` you can have a look to confirm if everything is in order before applying this in cluster. 142 | 143 | 7. The final step is to create the namespace `gitlab` and build with kustomize or kubectl. I prefer kustomize but you can also use kubectl with `-k` flag. 144 | 145 | * Create namespace 146 | ```bash 147 | kubectl create namespace gitlab 148 | ``` 149 | 150 | * Apply the final manifest 151 | ```bash 152 | kustomize build gitlab-k8s-1.0/ | kubectl apply -f - 153 | # or following if you have already changed into directory 154 | kustomize build . | kubectl apply -f - 155 | 156 | # With kubectl 157 | kubectl apply -k gitlab-k8s-1.0/ 158 | # or following if you have already changed into directory 159 | kubectl apply -k . 160 | ``` 161 | 162 | 8. Head over to the endpoint you have configured for gitlab `https://gitlab.example.com` and login. 163 | 164 | 165 | * Note: 166 | Default passwords 167 | > Gitlab 'root' user's password configured as secret 168 | ```bash 169 | LAwGTzCebner4Kvd23UMGEOFoGAgEHYDszrsSPfAp6lCW15S4fbvrVrubWsua9PI 170 | ``` 171 | > Postgres password configured as secret 172 | ```bash 173 | ZDVhZDgxNWY2NmMzODAwMTliYjdkYjQxNWEwY2UwZGMK 174 | ``` 175 | -------------------------------------------------------------------------------- /content/Guides/DevOps Toolchains/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: DevOps Toolchains 3 | --- 4 | 5 | DevOps is the next evolution of agile methodologies. A cultural shift that brings development and operations teams together. 6 | 7 | No specific DevOps tool or tools equate to “doing DevOps”, but there are plenty of tools that help enable the best practices that a DevOps culture promotes. Generally, these are tools that help streamline DevOps pipelines. 8 | 9 | 10 | 11 | #### DevOps Toolchains 12 | 13 | - [Gitlab Installation on Kuberntes]({{}} "gitlab") 14 | -------------------------------------------------------------------------------- /content/Guides/Get a free domain name and certificate/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Get a free domain name and certificate 3 | --- 4 | 5 | ___ 6 | 7 | With this tutorial you will get a valid SSL certificate from Let's Encrypt without having to open any incoming ports. You can use the certificate to enable HTTPS with your reverse proxy (Apache, Nginx, Caddy, ...) or other self hosted service. Since it only uses acme.sh which is a shell script it should work on everything that runs linux. 8 | 9 | The tutorial was written for and tested with Duck DNS and deSEC, but you can (in theory, because I did sadly encounter a few bugs/incompatibilities here and there) use [every of the 150+ DNS provider supported by acme.sh (there is also a second page at the end!)](https://github.com/acmesh-official/acme.sh/wiki/dnsapi). If you want to use a wildcard certificate I would recommend deSEC because Duck DNS currently has a bug/incompatibility with acme.sh. 10 | 11 | If you want to use another DNS provider you can skip right to [2. Install acme.sh](#2-install-acmesh), but need to change the parameter `--dns YOURDNS` in all the commands and set all necessary variables yourself according to the [acme.sh DNS API wiki](https://github.com/acmesh-official/acme.sh/wiki/dnsapi). 12 | 13 | 14 | ## 1. Sign in/up to a DynDNS provider 15 | 16 | #### 1. Duck DNS 17 | 18 | 1. Go to https://www.duckdns.org/ and sign in with one of the providers at the top. 19 | 20 | 2. After your are successfully logged in, enter the sub domain you want and press `add domain`. This domain name (including `.duckdns.org`) needs to be replaced in all commands where you see `YOURDOMAIN`. 21 | 22 | 3. Enter either 23 | 24 | 1. the local IP address of your server if your server is not accessible from the internet 25 | 26 | 2. or the public IP address of your server if your server is accessible from the internet 27 | 28 | in the `current ip` field and press `update ip`. 29 | 30 | The choosen sub domain name will be the one that the server/service needs to be addressed when using the certificate, for it to be valid. Since you set the sub domain to the IP address of your server it should be reachable when the sub domain name get's translated by any DNS. Depending on your home router you might need add an exception of the sub domain name to the DNS rebind protection. 31 | 32 | 4. Keep the website open, because you need it in a later step. 33 | 34 | 35 | #### 2. deSEC 36 | 37 | 1. Go to https://desec.io/signup and create a new account. It doesn't matter what you choose for `Do you want to set up a domain right away?` because you can add a domain afterwards. 38 | 39 | 2. Log into your deSEC account. 40 | 41 | 3. If you havent't added a domain during signup, click on the `+` button on the right and enter the subdomain you want and add `.dedyn.io` after your subdomain so it looks like `example.dedyn.io`. If the sub domain was added successfull there will be a popup with setup instructions which you will not need and can be closed. This domain name needs to be replaced in all commands where you see `YOURDOMAIN`. 42 | 43 | 4. Optionally add a DNS record: Click onto your sub domain name and then the `+` button on the right. A popup with `Create New Record Set` will show up. Choose the `Record Set Type` value `A` and enter either: 44 | 45 | 1. the local IP address of your server if your server is not accessible from the internet 46 | 47 | 2. or the public IP address of your server if your server is accessible from the internet 48 | 49 | in the `IPv4 address` field and press `save`. 50 | 51 | The choosen sub domain name will be the one that the server/service needs to be addressed when using the certificate, for it to be valid. Since you set the sub domain to the IP address of your server it should be reachable when the sub domain name get's translated by any DNS. Depending on your home router you might need add an exception of the sub domain name to the DNS rebind protection. 52 | 53 | 5. At the top menu change to `TOKEN MANAGEMENT` and press the `+` button on the right. A popup with `Generate New Token` will show up. Enter a token name of your choosing (the name doesn't matter and is only for the convenience of knowing what the token is used for) and press `save`. 54 | 55 | Now there will be a green bar at in the popup saying 56 | 57 | ``` 58 | Your new token's secret value is: aaaabbbbccccddddeeeeffffgggg 59 | It is only displayed once. 60 | ``` 61 | 62 | Copy the secret token value into an editor because you need it later. But don't worry, you can always come back to this step and generate a new token in case you loose the secret token value. 63 | 64 | 65 | ## 2. Install acme.sh 66 | 67 | 1. Install acme.sh: 68 | 69 | ```sh 70 | curl https://get.acme.sh | sh -s 71 | ``` 72 | 73 | If you wish to receive an expiration notification email before your certificates expires you can insert your email address and install acme.sh with the following command: 74 | 75 | ```sh 76 | curl https://get.acme.sh | sh -s email=my@example.com 77 | ``` 78 | 79 | You can find more information on expiration emails here: https://letsencrypt.org/docs/expiration-emails/ 80 | 81 | 2. Restart the terminal. 82 | 83 | 84 | ## 3. Configure acme.sh 85 | 86 | 1. Enable auto update: 87 | 88 | ```sh 89 | acme.sh --upgrade --auto-upgrade 90 | ``` 91 | 92 | 2. Change the default CA to Let's Encrypt (see explanation in the remarks): 93 | 94 | ```sh 95 | acme.sh --set-default-ca --server letsencrypt 96 | ``` 97 | 98 | 3. Take the token from the DynDNS provider website and insert it into either one of the following commands between the quotation marks: 99 | 100 | For deSEC: 101 | 102 | ```sh 103 | export DEDYN_TOKEN="aaaabbbbccccddddeeeeffffgggg" 104 | ``` 105 | 106 | For Duck DNS: 107 | 108 | ```sh 109 | export DuckDNS_Token="aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee" 110 | ``` 111 | 112 | 113 | ## 3. Issue a certificate 114 | 115 | In the following commands you need to replace `YOURDNS` with either `dns_duckdns` when you chose Duck DNS or `dns_desec` when you chose deSEC. 116 | 117 | Insert your registered sub domain in the following command to issue your first certificate: 118 | 119 | ```sh 120 | acme.sh --issue --dns YOURDNS --domain YOURDOMAIN 121 | ``` 122 | 123 | If you have registered more domains you can add them as alternative names to the certificate by adding more `--domain YOURDOMAIN` at the end: 124 | 125 | ```sh 126 | acme.sh --issue --dns YOURDNS --domain subdomain.example.com --domain subdomain-nextcloud.example.com --domain subdomain-vaultwarden.example.com 127 | ``` 128 | 129 | The first given `--domain` of the `--issue` command will be the primary domain of the certificate and the only one domain you will need to state when running other acme.sh commands. I would recommend to keep the primary domain the same when adding/removing other sub domains. 130 | 131 | 132 | ## 4. Install the certificate to a target directory 133 | 134 | After the certificate is issued acme.sh needs to copy the certificate to a target directory and can a command after each renewal of the certificate. 135 | 136 | The target directory and reload command specific to the primary domain (the domain of the first `--domain` parameter). So the target directory (or at least filename) must be unique and the reload command must be for this specific certificate. 137 | 138 | The following commad sets the variable `CERTIFICATE_DIRECTORY` (which is just for ease of use in the next command) with a directory of your choosing and creates the directory. 139 | 140 | ```sh 141 | CERTIFICATE_DIRECTORY=$HOME/certificates 142 | mkdir -p "$CERTIFICATE_DIRECTORY" 143 | ``` 144 | 145 | Now you tell acme.sh where and under which filenames it should copy the certificate (`--cert-file` and `--fullchain-file`) and key (`--key-file`) files and which command (`--reloadcmd`) it should run to restart your reverse proxy or other service. 146 | 147 | ```sh 148 | acme.sh --install-cert --domain YOURDOMAIN --cert-file "$CERTIFICATE_DIRECTORY/certificate.pem" --fullchain-file "$CERTIFICATE_DIRECTORY/fullchain.pem" --key-file "$CERTIFICATE_DIRECTORY/key.pem" --reloadcmd "sudo service apache2 force-reload" 149 | ``` 150 | 151 | 152 | ## 5. Automatic renewal 153 | 154 | Certificates are only valid for 90 days. Because of this acme.sh will create a daily cron job running at a random time at night that will: 155 | * renew every certificate after 60 days 156 | * copy the certificate and key files to their destination (as configured in [4. Install the certificate to a target directory](#4-install-the-certificate-to-a-target-directory)) 157 | * run the reload command (as configured in [4. Install the certificate to a target directory](#4-install-the-certificate-to-a-target-directory)) 158 | 159 | ___ 160 | 161 | ### Remarks: 162 | 163 | 1. How can I add more domain names to my certificate? 164 | 165 | Run the command from [3. Issue a certificate](#3-issue-a-certificate) again with all domain names (old and new) that you want in your certificate. As long as the primary domain stays the same it is not necessary to install the certificate again. 166 | 167 | After changing the domnain names with the `--issue` command, it will not copy the new certificate to it's destination or run the `--reloadcmd` that was set with the `--install-cert` command. You will either have to do it by yourself or run the `--install-cert` command again (with all the same parameters as before) or copy the files manually from the `.acme.sh` directory in your home directory. If you don't know the parameters from last time you can look them up in the info about the certificate (see next point). 168 | 169 | 1. Show configuration of acme.sh: 170 | 171 | ```sh 172 | acme.sh --info 173 | ``` 174 | 175 | 1. Show configuration of a certificate: 176 | 177 | ```sh 178 | acme.sh --info -d YOURDOMAIN 179 | ``` 180 | 181 | 1. List all certificates issued with acme.sh: 182 | 183 | ```sh 184 | acme.sh --list 185 | ``` 186 | 187 | 1. Remove a certificate from acme.sh: 188 | 189 | ```sh 190 | acme.sh --remove -d YOURDOMAIN 191 | ``` 192 | 193 | 1. Why change the default CA to Let's Encrypt? 194 | 195 | I did encounter bugs with the default CA of acme.sh (ZeroSSL) which where gone once I switched to Let's Encrypt. 196 | 197 | 1. How to create a wildcard certificate: 198 | 199 | Add *.YOURSUBDOMAIN.YOURSITEDOMAIN.com as an alternative domain name to your certificate: 200 | 201 | ```sh 202 | acme.sh --issue --dns dns_... --domain YOURSUBDOMAIN.YOURSITEDOMAIN.com --domain *.YOURSUBDOMAIN.YOURSITEDOMAIN.com 203 | ``` 204 | 205 | In theory it works with Duck DNS, but if you add the wildcard as an alternative name there sadly is a bug or incompatibility (depending on who you want to blame) and acme.sh runs into an infitie loop. It works if you only use the wildcard domain as the primary domain name. But with only a wildcard in the certificate I don't know if this certificate will play nice with all devices, browsers and applications. 206 | 207 | If you want to use acme.sh and create a wildcard certificate desec.io works as a DNS provider. 208 | 209 | 1. How to create a staging certificate for testing: 210 | 211 | Add the `--test` parameter to the `--issue` command to create test (or staging) certificates which are not valid but are better if you are just testing things. The certificate will stay in the staging environment until you renew it without the `--test` parameter: 212 | 213 | ```sh 214 | acme.sh --renew -d YOURSUBDOMAIN.YOURSITEDOMAIN.com 215 | ``` 216 | 217 | More on that topic here: https://letsencrypt.org/docs/staging-environment/ 218 | 219 | 1. Uninstall acme.sh: 220 | 221 | ```sh 222 | acme.sh --uninstall 223 | ``` 224 | 225 | and delete the `.acme.sh` directory in your home directory. 226 | -------------------------------------------------------------------------------- /content/Guides/Reverse Proxy Servers/Nginx/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Nginx Reverse Proxy 3 | tags: [normal] 4 | --- 5 | ___ 6 | ## What is a reverse proxy? 7 | To learn what a reverse proxy is and why you should use one, read the explanation [here](/explanations/#reverse-proxies). 8 | 9 | ## Prerequisites 10 | There are some prerequisites you'll need before setting up a reverse proxy server. The first thing you'll need is to have port 80 and 443 of your public IP address forwarded to the machine you want to use as a proxy. This can be configured through your router's admin page. You will also need a domain name with an A record that points to your public IP. Finally, you'll need some services running on your local network for you to proxy. 11 | 12 | ## nginx installation 13 | 14 | ### Debian-based systems 15 | First, type `sudo apt update` to update the package information. 16 | Then, type `sudo apt install nginx` to install nginx. 17 | Finally, allow the necessary ports using `sudo ufw allow 80/tcp` and `sudo ufw allow 443/tcp`. 18 | ### RHEL-based systems 19 | First, enable the EPEL repository using `sudo yum install epel-release`. 20 | Then, type `sudo yum install nginx` to install nginx. 21 | Finally, allow the necessary ports using `sudo firewall-cmd --permanent --zone=public --add-service=http` and `sudo firewall-cmd --permanent --zone=public --add-service=https`. Also, type `sudo firewall-cmd --reload` to reload the firewall. 22 | 23 | Make sure nginx starts up using `sudo systemctl start nginx`. 24 | 25 | To verify that nginx is working properly, visit `http://yoursite.com` and you should see a nginx welcome page similar to what's shown below. This specific page may vary depending on your distro. 26 | 27 | ![Nginx Welcome Page][1] 28 | 29 | ## Deciding the reverse proxy structure 30 | 31 | Before we actually create our reverse proxy configuration, we have to decide which local servers will handle each of the subdomains. For example, if I wanted `nextcloud.yoursite.com` to be handled by a server at `192.168.0.230`, I could add a nginx configuration for that. 32 | 33 | Once you've decided which subdomains you'll use, add DNS CNAME records that map the subdomain to your main domain name. Below is an example in Google Domains, but it will vary depending on your DNS provider. 34 | 35 | ![Google Domains CNAME Records][2] 36 | 37 | ## Modifying the configuration files 38 | Note: Editable templates for each of the config files shown in this guide can be found at [this GitHub repo](https://github.com/Rav4s/NginX-Config-Files). 39 | 40 | In order to set up the reverse proxy, we have to remove the default website and add our own configuration to handle each subdomain. In this guide, we'll create two config files, one for a www/non-www domain and one for any other subdomain. 41 | 42 | ### Removing the default configuration 43 | 44 | To remove the default configuration, we can type `cd /etc/nginx/sites-enabled/` to enter the directory and `sudo rm default` to remove the config file. 45 | 46 | ### Creating the first config file 47 | 48 | To begin, type `cd /etc/nginx/sites-available/` to enter the sites-available directory. Then type `sudo vi reverse-proxy.conf` to begin editing the file. 49 | 50 | The first thing you'll want to add in this file is a server block. This server block will listen on `http://www.yoursite.com` and redirect visitors to `https://www.yoursite.com`. 51 | 52 | ``` 53 | server { 54 | listen 80; 55 | server_name www.yoursite.com; 56 | return 301 https://www.yoursite.com$request_uri; 57 | } 58 | ``` 59 | 60 | The next thing to add is another server block, which will listen on `http://yoursite.com` and redirect visitors to `https://www.yoursite.com` 61 | 62 | ``` 63 | server { 64 | listen 80; 65 | server_name yoursite.com; 66 | return 301 https://www.yoursite.com$request_uri; 67 | } 68 | ``` 69 | 70 | Our third server block will listen on `https://yoursite.com`, and redirect the https traffic to `https://www.yoursite.com`. This server block also contains information about the SSL certificates, which we will modify later when we obtain them. 71 | 72 | ``` 73 | server { 74 | listen 443; 75 | server_name yoursite.com; 76 | return 301 https://www.yoursite.com$request_uri; 77 | 78 | # SSL Configuration 79 | 80 | ssl_certificate /etc/letsencrypt/live/yoursite.com/fullchain.pem; # managed by Certbot 81 | ssl_certificate_key /etc/letsencrypt/live/yoursite.com/privkey.pem; # managed by Certbot 82 | ssl on; 83 | ssl_session_cache builtin:1000 shared:SSL:10m; 84 | ssl_protocols TLSv1 TLSv1.1 TLSv1.2; 85 | ssl_ciphers HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4; 86 | ssl_prefer_server_ciphers on; 87 | 88 | } 89 | ``` 90 | 91 | This last server block will perform the actual proxying. It will listen on `https://www.yoursite.com` and proxy requests to a backend server. To do this, we can add a location block within this server block. Within the location block, we set proxy headers which nginx forwards to the backend, and we add the proxy pass and proxy redirect with the IP address and port of the backend server. The last few lines are optional, but I recommend using them because they heighten the security of your server. These lines enable HSTS, clickjacking protection, XSS protection, and disable content and MIME sniffing. Finally, we can add a line which adds the trailing slash to all URLs. 92 | 93 | ``` 94 | server { 95 | 96 | listen 443; 97 | server_name www.yoursite.com; 98 | 99 | # SSL Configuration 100 | 101 | ssl_certificate /etc/letsencrypt/live/yoursite.com/fullchain.pem; # managed by Certbot 102 | ssl_certificate_key /etc/letsencrypt/live/yoursite.com/privkey.pem; # managed by Certbot 103 | ssl on; 104 | ssl_session_cache builtin:1000 shared:SSL:10m; 105 | ssl_protocols TLSv1 TLSv1.1 TLSv1.2; 106 | ssl_ciphers HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4; 107 | ssl_prefer_server_ciphers on; 108 | 109 | # Set the access log location 110 | 111 | access_log /var/log/nginx/yoursite.access.log; 112 | 113 | location / { 114 | 115 | # Set the proxy headers 116 | 117 | proxy_set_header Host $host; 118 | proxy_set_header X-Real-IP $remote_addr; 119 | proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 120 | proxy_set_header X-Forwarded-Proto $scheme; 121 | 122 | # Configure which address the request is proxied to 123 | 124 | proxy_pass http://yourserverip:yourport/; 125 | proxy_read_timeout 90; 126 | proxy_redirect http://yourserverip:yourport https://www.yoursite.com; 127 | 128 | # Security headers 129 | add_header Strict-Transport-Security "max-age=31536000; includeSubDomains; preload"; 130 | add_header X-Frame-Options DENY; 131 | add_header X-Content-Type-Options nosniff; 132 | add_header X-XSS-Protection "1; mode=block"; 133 | add_header Referrer-Policy "origin"; 134 | 135 | # Add the trailing slash 136 | rewrite ^([^.]*[^/])$ $1/ permanent; 137 | } 138 | 139 | } 140 | ``` 141 | 142 | After adding these lines, type `:wqa` to save the file and exit Vim. 143 | 144 | There's one more step before we can use this config: symlinking it to the sites-enabled directory (which nginx reads). To do this, type `sudo ln -s /etc/nginx/sites-available/reverse-proxy.conf /etc/nginx/sites-enabled/reverse-proxy.conf`. 145 | 146 | ### Creating the second config file 147 | 148 | This next config file will serve as a template for any other subdomains you want to add to your reverse proxy. To begin making this config file, type `cd /etc/nginx/sites-available/` and then `sudo vi SUBDOMAIN.conf`, replacing "SUBDOMAIN" with the subdomain you want to configure. 149 | 150 | The first thing we'll add in this file is a server block. This server block will listen on `http://YOURSUBDOMAIN.YOURSITEDOMAIN.com` and redirect visitors to `https://YOURSUBDOMAIN.YOURSITEDOMAIN.com`. 151 | 152 | ``` 153 | server { 154 | listen 80; 155 | server_name YOURSUBDOMAIN.YOURSITEDOMAIN.com; 156 | return 301 https://$host$request_uri; 157 | } 158 | ``` 159 | 160 | This next server block will perform the actual proxying. It will listen on `https://YOURSUBDOMAIN.YOURSITEDOMAIN.com` and proxy requests to your backend server. To do this, we'll add a location block inside the server block. Within the location block, we set proxy headers which nginx forwards to the backend, and we add the proxy pass and proxy redirect with the IP address and port of the backend server. Again, the security headers at the bottom are optional, but they will greatly improve the security of your server, so I recommend that you add them. 161 | 162 | ``` 163 | server { 164 | 165 | listen 443; 166 | server_name YOURSUBDOMAIN.YOURSITEDOMAIN.com; 167 | 168 | # SSL configuration 169 | 170 | ssl_certificate /etc/letsencrypt/live/YOURSUBDOMAIN.YOURSITEDOMAIN.com/fullchain.pem; # managed by Certbot 171 | ssl_certificate_key /etc/letsencrypt/live/YOURSUBDOMAIN.YOURSITEDOMAIN.com/privkey.pem; # managed by Certbot 172 | ssl on; 173 | ssl_session_cache builtin:1000 shared:SSL:10m; 174 | ssl_protocols TLSv1 TLSv1.1 TLSv1.2; 175 | ssl_ciphers HIGH:!aNULL:!eNULL:!EXPORT:!CAMELLIA:!DES:!MD5:!PSK:!RC4; 176 | ssl_prefer_server_ciphers on; 177 | 178 | # Set the access log location 179 | 180 | access_log /var/log/nginx/YOURSUBDOMAIN.access.log; 181 | 182 | location / { 183 | 184 | # Set the proxy headers 185 | 186 | proxy_set_header Host $host; 187 | proxy_set_header X-Real-IP $remote_addr; 188 | proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 189 | proxy_set_header X-Forwarded-Proto $scheme; 190 | 191 | # Configure which address the request is proxied to 192 | 193 | proxy_pass http://YOURSERVER:YOURPORT; 194 | proxy_read_timeout 90; 195 | proxy_redirect http://YOURSERVER:YOURPORT https://YOURSUBDOMAIN.YOURSITEDOMAIN.com; 196 | 197 | # Set the security headers 198 | 199 | add_header Strict-Transport-Security "max-age=31536000; includeSubDomains; preload"; #HSTS 200 | add_header X-Frame-Options DENY; #Prevents clickjacking 201 | add_header X-Content-Type-Options nosniff; #Prevents MIME sniffing 202 | add_header X-XSS-Protection "1; mode=block"; #Prevents cross-site scripting attacks 203 | add_header Referrer-Policy "origin"; 204 | } 205 | 206 | } 207 | ``` 208 | 209 | After adding these lines, type `:wqa` to save the file and exit Vim. 210 | 211 | Finally, to symlink this file to the sites-enabled directory, type `sudo ln -s /etc/nginx/sites-available/SUBDOMAIN.conf /etc/nginx/sites-enabled/SUBDOMAIN.conf`. 212 | 213 | To add any additional subdomains, simply copy the previous config file and replace the server_name with the new subdomain, along with the backend's IP address and port. Then symlink the new file to the sites-enabled directory. 214 | 215 | ## Restarting nginx 216 | 217 | If you try to restart nginx at this stage (`sudo systemctl restart nginx`), you'll probably see a few errors saying that the certificate files don't exist. In order to get nginx to start, we'll have to use a temporary certificate. 218 | 219 | To obtain a temporary certificate and store it in the working directory, type `openssl req -newkey rsa:2048 -nodes -keyout key.pem -x509 -days 365 -out certificate.pem`. Two files, `key.pem` and `certificate.pem` will be stored in your working directory. 220 | 221 | Now modify these two lines in your config files 222 | 223 | ` ssl_certificate /etc/letsencrypt/live/yoursite.com/fullchain.pem; # managed by Certbot` 224 | `ssl_certificate_key /etc/letsencrypt/live/yoursite.com/privkey.pem; # managed by Certbot` 225 | 226 | so that they look like this: 227 | 228 | `ssl_certificate /path/to/certificate.pem; # managed by Certbot` 229 | `ssl_certificate_key /path/to/key.pem; # managed by Certbot` 230 | 231 | Make sure to replace `/path/to/` with the path to your certificate and key files. 232 | 233 | After modifying these lines in each config, we can restart nginx using `sudo systemctl restart nginx`. 234 | 235 | ## Obtaining Let's Encrypt SSL certificates 236 | 237 | Now that nginx has restarted with the new configuration, we can obtain SSL certificates from Let's Encrypt, a certificate authority that provides free certificates. To obtain a Let's Encrypt certificate, we can use Certbot. 238 | 239 | To install Certbot on a Debian-based distro, type `sudo apt install python3-certbot-nginx`. 240 | 241 | To install on a RHEL-based distro, type `sudo yum install certbot python3-certbot-nginx`. 242 | 243 | Then, to obtain certificates for your www and non-www domains, type `sudo certbot --nginx -d YOURSITEDOMAIN.com -d www.YOURSITEDOMAIN.com`. 244 | 245 | Certbot will ask for some information, including your email address, agreement to the Terms of Service, and whether or not you want to subscribe to their newsletter. Then, Certbot will obtain your certificate. 246 | 247 | To obtain a certificate for any additional subdomains, type `sudo certbot --nginx -d sub.domain.com`, replacing `sub.domain.com` with the proper subdomain address. 248 | 249 | Certbot will automatically update the config files with the path to your new certificates, so you don't need to do that manually. 250 | 251 | Once you've obtained all the certificates you need, restart nginx with `sudo systemctl restart nginx`. 252 | 253 | Now, visit each of your subdomains and ensure that they are accessible over https. 254 | 255 | ### Auto-renewal cron job 256 | 257 | The last thing we should do is to set up the auto-renewal of SSL certificates using cron. To do this, open the crontab for editing by typing `sudo crontab -e`. 258 | 259 | Then add the following line to the crontab to automatically try to renew the certificates at 1:00am every day: 260 | 261 | `0 1 * * * certbot renew --deploy-hook "systemctl restart nginx"` 262 | 263 | ## Conclusion 264 | 265 | In conclusion, a reverse proxy allows you to easily host multiple sites on the same IP address without exposing unnecessary ports. If you enjoyed this article, feel free to check out [my website](https://www.yeetpc.com), where I post articles about upgrading/restoring computers, securing your servers, and more. Thanks for reading and happy self-hosting! 266 | 267 | [1]:  268 | 269 | [2]:  270 | -------------------------------------------------------------------------------- /content/Guides/Reverse Proxy Servers/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Reverse Proxy Servers 3 | --- 4 | 5 | Reverse proxies are daemons that accept connections based on host or port, establish a connection to a backend service based on the connection request, and pass data between the client/backend. 6 | 7 | #### Reverse proxy servers 8 | 9 | - [nginx]({{}} "nginx") 10 | -------------------------------------------------------------------------------- /content/Guides/Virtual Private Networks/Wireguard/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: WireGuard 3 | tags: [normal] 4 | --- 5 | 6 | WireGuard is a secure VPN tunnel that aims to provide a VPN that is easy to use, fast, and with low overhead. 7 | 8 | It is cross-platform, but it is the part of the Linux kernel by default with only the need of userland tools to configure and deploy it. 9 | 10 | #### Preface 11 | 12 | From now on, we are going to assume that we are working on Linux to configure WireGuard with one server and at least one client. 13 | 14 | This guide assumes that this configuration is being performed as root or the superuser. For your distribution this may require you to prefix commands with 'sudo'. 15 | 16 | #### Installation 17 | 18 | You can find more details about installing WireGuard on your own operating system here: https://www.wireguard.com/install/. Please complete installation for both the server and client machine. 19 | 20 | ##### Make the keys 21 | 22 | The first step after installing WireGuard for your distribution is to generate keys. We should do this for the server first, but this will be the same for clients as well. 23 | 24 | cd /etc/wireguard && wg genkey | tee private.key | wg pubkey > public.key 25 | 26 | You should now have **public.key** and **private.key** files in */etc/wireguard/*. 27 | 28 | >It is important to make sure your private key stays private. No private key should ever leave the machine it was generated on. The client and server will only need the public keys for each other. If you are using the private keys for a client on a server, or vice-versa, you are doing something wrong. 29 | 30 | #### Server configuration 31 | 32 | Since this is the server, we need to make a new configuration file for it in */etc/wireguard/*. We will call it **wg0.conf**. The full path should end up being */etc/wireguard/wg0.conf*. 33 | 34 | >Please use your own private key where appropriate. You can view the contents of a text file from the command line with *cat* (e.g.: **cat /path/to/text.file**). 35 | 36 | You can change the **Address** field to use a different address space (e.g.: 192.168.x.1) if you wish. If your server or clients are already using private IP space on a LAN, **use something different**. 37 | 38 | [Interface] 39 | ## Private IP address for the server to use 40 | Address = 10.0.0.1/24 41 | ## When WG is shutdown, flushes current running configuration to disk. Any changes made to the configuration before shutdown will be forgotten 42 | SaveConfig = true 43 | ## The port WG will listen on for incoming connections. 51194 is the default 44 | ListenPort = 51194 45 | ## The server's private key. Not a file path, use the key file contents 46 | PrivateKey = PRIVATEKEY 47 | 48 | After this is done we should be able to start the VPN tunnel and make sure it's enabled. 49 | 50 | >Please consult the documentation for your Linux distribution for enabling/starting services. This guide is using system tools installed on Debian and Debian-based distributions. 51 | 52 | ##### *Debian* 53 | 54 | systemctl enable wg-quick@wg0 && systemctl start wg-quick@wg0 55 | 56 | That should be it for the server portion. 57 | 58 | #### Client configuration 59 | 60 | The client will need keys too. Use the same procedure to [make keys]({{}} "make keys") for the client as we've done for the server. 61 | 62 | Once that is done we need to create a client configuration. Let's make **wg0-client.conf** in */etc/wireguard/*. Full path should be */etc/wireguard/wg0-client.conf*. 63 | 64 | You will need to choose a unique IP for the client. Everything should be the same as the server's private IP except the last octet. 65 | 66 | [Interface] 67 | ## This Desktop/client's private key ## 68 | PrivateKey = CLIENTPRIVATEKEY 69 | 70 | ## Client IP address ## 71 | Address = 10.0.0.CLIENTOCTET/32 72 | 73 | [Peer] 74 | ## WG server public key ## 75 | PublicKey = WGSERVERPUBLICKEY 76 | 77 | ## set ACL ## 78 | ## Uncomment the next line to use VPN for VPN connections only 79 | # AllowedIPs = 10.0.0.0/24 80 | ## If you want to use the VPN for ALL network traffic, uncomment the following line instead 81 | # AllowedIPs = 0.0.0.0/0 82 | 83 | ## Your WG server's PUBLIC IPv4/IPv6 address and port ## 84 | Endpoint = WGSERVERPUBLICIP:51194 85 | 86 | ## Key connection alive ## 87 | PersistentKeepalive = 20 88 | 89 | This should be all you need for configuring the client-end connection. We will need the private client IP you've chosen and the public client key in a bit. 90 | 91 | As with the server, we need to enable the WireGuard client service. We don't start it yet because the server still doesn't know about this client. 92 | 93 | ##### *Debian* 94 | 95 | systemctl enable wg-quick@wg0-client 96 | 97 | #### Configuring the client as a peer 98 | 99 | Back on your server, we need to add the client so the server will accept the client connection. This is where your client private IP and public key will be used. 100 | 101 | Run the following command on the WG server to add the client. 102 | 103 | wg set wg0 peer CLIENTPUBLICKEY allowed-ips CLIENTPRIVATEIP/32 104 | 105 | You should not need to restart the WireGuard service. 106 | 107 | Let's start the WG client service on the client: 108 | 109 | ##### *Debian* 110 | 111 | systemctl start wg-quick@wg0-client 112 | 113 | To check that it works, ping the WG server on its private IP. 114 | 115 | 116 | $ ping -c 1 10.0.0.1 117 | PING 10.0.0.1 (10.0.0.1) 56(84) bytes of data. 118 | 64 bytes from 10.0.0.1: icmp_seq=1 ttl=64 time=0.071 ms 119 | 120 | --- 10.0.0.1 ping statistics --- 121 | 1 packets transmitted, 1 received, 0% packet loss, time 0ms 122 | rtt min/avg/max/mdev = 0.071/0.071/0.071/0.000 ms 123 | 124 | If you consider your client Internet connection stable, this next step may not be necessary. You can consider yourself done if you wish. 125 | 126 | THE END (maybe) 127 | 128 | #### WireGuard watchdog (OPTIONAL) 129 | 130 | Next we are going to setup a small cron job that will ping the WG server on its private IP to make sure the connection is still intact. If the connection fails, the tunnel will be restarted. 131 | 132 | You can put this script anywhere, but I usually choose to put it in */usr/local/scripts/*. 133 | 134 | mkdir /usr/local/scripts 135 | 136 | Now for the script. I use **wg-watch.sh**. Let's assume you are going to use */usr/local/scripts/wg-watch.sh* for the **full file path**. 137 | 138 | 139 | #!/usr/bin/bash 140 | # Modified from https://mullvad.net/en/help/running-wireguard-router/ 141 | # ping VPN gateway to test for connection 142 | # if no contact, restart! 143 | 144 | PING=/usr/bin/ping 145 | ## DEBIAN 146 | SERVICE=/usr/sbin/service 147 | 148 | tries=0 149 | while [[ $tries -lt 3 ]] 150 | do 151 | if $PING -c 1 10.0.0.1 152 | then 153 | echo "wg works" 154 | exit 0 155 | fi 156 | echo "wg fail" 157 | tries=$((tries+1)) 158 | done 159 | echo "wg failed 3 times - restarting tunnel" 160 | ## DEBIAN 161 | $SERVICE wg-quick@wg0-client restart 162 | 163 | >Please make sure the paths to certain binaries are congruent with your own system. If they are not, the script will fail. Some distributions put them in different places (e.g.: /bin/bash instead of /usr/bin/bash). If you are not sure where they are, you can do `which binaryname` that should report the full path to the binary. 164 | 165 | $ which bash 166 | /usr/bin/bash 167 | 168 | Make the script executable: 169 | 170 | chmod +x /usr/local/scripts/wg-watch.sh 171 | 172 | 173 | Once we have that done, we need to schedule it. I choose to schedule this every five minutes, but if you want to wait longer that is up to you. 174 | 175 | Schedule the script to run on a regular basis using *cron*. You can find out more about cron here: https://opensource.com/article/17/11/how-use-cron-linux 176 | 177 | We're going to use *crontab* to add this script to the list of jobs. 178 | 179 | crontab -e 180 | 181 | Once the crontab editor is open, add this: 182 | 183 | */5 * * * * /usr/local/scripts/wg-watch.sh 184 | 185 | Write and close the file. Crontab should confirm that it has been updated. 186 | 187 | You should be set with a WireGuard VPN tunnel between a server and a client along with a script to bring the tunnel back up if it fails. 188 | -------------------------------------------------------------------------------- /content/Guides/Virtual Private Networks/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Virtual Private Networks 3 | --- 4 | 5 | Virtual private networks allow you to network any individual computers together into their own network in software. There are many options available. 6 | 7 | Traditional VPN solutions are L2TP/IPsec, OpenVPN, IKEv2 and PPTP. A more modern VPN software solution is WireGuard. You will find information on how to setup your own VPN in this section. 8 | 9 | #### Virtual private network software 10 | 11 | - [WireGuard]({{}} "WireGuard") 12 | -------------------------------------------------------------------------------- /content/Guides/Webservers/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Webservers 3 | --- 4 | -------------------------------------------------------------------------------- /content/Guides/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Guides 3 | --- 4 | 5 | 6 | 7 | Find the link to your desired guide below! 8 | 9 | #### Reverse proxies 10 | 11 | - [nginx]({{}} "nginx") 12 | 13 | #### Virtual private networks 14 | 15 | - [WireGuard]({{}} "WireGuard") 16 | 17 | #### DevOps Toolchains 18 | 19 | - - [Gitlab Installation on Kuberntes]({{}} "gitlab") -------------------------------------------------------------------------------- /content/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: /r/Selfhosted Official Wiki 3 | --- 4 | 5 | # /r/SelfHosted Official Wiki 6 | ___ 7 | 8 | ## Welcome to the Wiki 9 | We welcome you to explore the pages here and familiarize yourself with the layout of the wiki. If you have any suggestions for better/alternative organization methods, or feedback/questions in general about the wiki, feel free to reach out to: 10 | - [our subreddit moderators](https://www.reddit.com/message/compose/?to=/r/selfhosted) 11 | - [Discord channel](https://discord.gg/BHDByBdKEV) 12 | - [Matrix](https://matrix.to/#/#selfhosted:matrix.org) | View online: [Elements](https://app.element.io/#/room/#selfhosted:matrix.org) 13 | 14 | ### Getting started 15 | 16 | Here you can find a couple of articles about the best ways to get started based on what you're looking to accomplish. 17 | 18 | * Learn about what self-hosting is 19 | * Learn about hosting websites 20 | * Learn about using reverse proxies 21 | * Learn about self-hosted alternatives to popular services and providers 22 | * Learn about the most common ways to self-host 23 | -------------------------------------------------------------------------------- /content/tags/easy/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Easy Tag 3 | --- 4 | -------------------------------------------------------------------------------- /content/tags/hard/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Hard Tag 3 | --- 4 | -------------------------------------------------------------------------------- /content/tags/normal/_index.md: -------------------------------------------------------------------------------- 1 | --- 2 | Title: Normal Tag 3 | --- 4 | 5 | 6 | -------------------------------------------------------------------------------- /layouts/partials/favicon.html: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /layouts/partials/logo.html: -------------------------------------------------------------------------------- 1 | Selfhosted Logo 2 |
/r/Selfhosted Official Wiki
3 | -------------------------------------------------------------------------------- /static/images/favicon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/r-selfhosted-wiki/wiki/d2588cd7e5811361898f983e0022eb8df0726f0c/static/images/favicon.png -------------------------------------------------------------------------------- /static/images/logo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/r-selfhosted-wiki/wiki/d2588cd7e5811361898f983e0022eb8df0726f0c/static/images/logo.png --------------------------------------------------------------------------------