diff --git a/content/posts/bgp-ecmp-load-balancing.md b/content/posts/bgp-ecmp-load-balancing.md index 15352f7..e839788 100644 --- a/content/posts/bgp-ecmp-load-balancing.md +++ b/content/posts/bgp-ecmp-load-balancing.md @@ -31,7 +31,7 @@ References: ## Configure -### ISPRouter +### ISPRouter Follow the [Fortigate document](https://docs.fortinet.com/document/fortigate/7.0.3) for the basic commands. @@ -82,7 +82,7 @@ config firewall policy end ``` -### EdgeRouter +### EdgeRouter ```bash config system interface @@ -147,7 +147,7 @@ config system settings end ``` -### Switch +### Switch - Set up mode access. @@ -160,7 +160,7 @@ exit copy running-config start-config ``` -### Servers +### Servers - Configure `10.13.13.1` on the local loopback interface. @@ -341,7 +341,7 @@ lb1$ sudo service exabgp status To make sure everything works as expected. -### Scenario 1: Both servers are OK +### Scenario 1: Both servers are OK - Client check. @@ -443,7 +443,7 @@ Origin codes: i - IGP, e - EGP, ? - incomplete Total number of prefixes 1 ``` -### Scenario 2: One lb is down +### Scenario 2: One lb is down - Stop nginx on lb2 (ExaBGP only, Bird may require the complete shutdown) or stop lb2 physically. diff --git a/content/posts/docker-iptables.md b/content/posts/docker-iptables.md index c00a582..834b76c 100644 --- a/content/posts/docker-iptables.md +++ b/content/posts/docker-iptables.md @@ -29,7 +29,7 @@ This is a basic packet flow from outside: Alright, before we make it right, there are some common mistakes. -### Modify Docker generated rules manually +### Modify Docker generated rules manually Docker generates iptables rules, then adds to `DOCKER` chains. Some users may manipulate this chain manually in order to block connections. @@ -39,7 +39,7 @@ _Please don't do it_. Yes, you are able to do it, there is nothing prevent you t Right: Do not manipulate Docker rules manually. {{< /quote >}} -### Insert you rules in the wrong chain +### Insert you rules in the wrong chain iptables basic: iptables is divied into three levels: tables, chains and rules. We only use the filter tables, which contains: @@ -53,7 +53,7 @@ Commonly, to block connection from external, put reject rules in INPUT chain. Bu Right: Add rules which load before Docker's rules, add them to DOCKER-USER. {{< /quote >}} -### Modify and persistent iptables wrong +### Modify and persistent iptables wrong You modify and persistent iptables rules like this: @@ -70,7 +70,7 @@ Right: Do not save, flush then restore all rules. Check the following solution. ## Do it right! -### Overview +### Overview I have create a repository for this, which is highly inspired by [systemd-service-iptables](https://github.com/boTux-fr/systemd-service-iptables): https://github.com/ntk148v/systemd-iptables @@ -234,7 +234,7 @@ I have create a repository for this, which is highly inspired by [systemd-servic COMMIT ``` -### Getting started +### Getting started - Ofc you need iptables and systemd installed. - On the Linux, run as root: diff --git a/content/posts/getting-started-tiling-wm-part-1-i3.md b/content/posts/getting-started-tiling-wm-part-1-i3.md index f1b2de0..ae579b9 100644 --- a/content/posts/getting-started-tiling-wm-part-1-i3.md +++ b/content/posts/getting-started-tiling-wm-part-1-i3.md @@ -17,7 +17,7 @@ I love customizing desktop. I make changes in my desktop everyday, make it look First of all, you have to know the basic concepts. -### Desktop Environment vs. Window Manager +### Desktop Environment vs. Window Manager We'll begin by showing how the Linux graphical desktop is layered. There are basically 3 layers that can be included in the Linux desktop: @@ -40,7 +40,7 @@ A[Desktop Environment] --> B[Window Manager]; B --> C[X Windows]; {{< /mermaid >}} -### Types of Window Manager +### Types of Window Manager - **Stack window manager**: - A stack window manager renders the window one-by-one onto the screen at specific co-orinates. If one window's area overlaps another, then the window "on top" overwites part of the other's visible appearance. This results in the appearance familiar to many users in which windows act a little like pieces of paper on a desktop, which can be moved around and allowed to overlap. @@ -65,7 +65,7 @@ B --> C[X Windows]; ## Minimal I3 setup -### Operating System +### Operating System - Ubuntu 20.04 (Desktop/Server), download the [installer](https://ubuntu.com/download/) and install Ubuntu by walking through installer. - If you choose Ubuntu Server, you'll need a display server so let's install X Window System ([Xorg](https://wiki.archlinux.org/index.php/Xorg)). @@ -76,7 +76,7 @@ sudo apt install xinit # You can override it by creating and modifying ~/.xinitrc ``` -### Install I3 +### Install I3 - You can install i3 from [Ubuntu repository](https://packages.ubuntu.com/search?keywords=i3). It includes the window manager, a screen locker and two programs which write a status line to i3bar through stdout. @@ -124,14 +124,14 @@ sudo ninja install This post doesn't aim to cover everything about i3, see the [official documentation](https://i3wm.org/docs/userguide.html) for more information. -### Keybindings +### Keybindings - In i3, commands are invoked with a modifier key, referred to as `$mod`. This is `Alt (Mod1)` by default, with `Super (Mod4)` being a popular alternative. Super is the key usually represented on a keyboard as a Windows icon, or on an Apple keyboard as a Command key. - See [i3 reference card](https://i3wm.org/docs/refcard.html) and [Using i3](https://i3wm.org/docs/userguide.html#_using_i3) for defaults. {{< figure class="figure" src="/photos/getting-started-tiling-wm-part-1/i3-refcard.png" >}} -### Workspace, Container and Window +### Workspace, Container and Window {{< mermaid >}} @@ -165,7 +165,7 @@ style Container3 fill:#6fa8dc; - A window, where an application is running, can be created in a container. It will automatically position itself and be in focus, depending on the container’s layout. You can move them around or even change the layout of the container using keystrokes. - There are two different sorts of windows: **fixed window**s (by default) and **floating windows**. -### Application launcher +### Application launcher - i3 uses [dmenu](https://wiki.archlinux.org/title/Dmenu) as an application launcher, which is bound by default to `$mod+d`. - [rofi]({{< ref "/posts/getting-started-tiling-wm-part-2-rofi.md" >}}) is a popular dmenu replacement and more that can list dekstop entries. diff --git a/content/posts/linux-swap-space-note.md b/content/posts/linux-swap-space-note.md index d8c41a4..e124d3b 100644 --- a/content/posts/linux-swap-space-note.md +++ b/content/posts/linux-swap-space-note.md @@ -14,7 +14,7 @@ Swap file systems support virtual memory, data is written to a swap file system ## Swap partition size -### Old rule of thumb +### Old rule of thumb ``` swap: 2 * the-amount-of-RAM @@ -22,7 +22,7 @@ swap: 2 * the-amount-of-RAM So if a computer had 64KB of RAM, a swap partition of 128KB would be an optimum size. This rule took into the facts that RAM sizes were typically quite small at the time. Nowadays, RAM has become a `cheap` & `affordable` commondity, so the 2x rule is outdated. -### What is the right amount of swap space? +### What is the right amount of swap space? Choosing the correct swap size is important. Too much swap space can hide memory leaks, also the storage space is allocated but idle. It can affect the system performance in general. @@ -41,11 +41,11 @@ swap <= 10% * total-size-hard-drives && swap <= 128GB (if hibernation is allowed ## Common misconceptions & gotchas -### Increasing swap size would increase performance +### Increasing swap size would increase performance - No, it wouldn't. Remember that the slowest part of memory is your hard-disk - _swap_ just provides the ability to use more memory by swapping some pages out to the disk, which is **slow** compared to RAM operations. Swap can also [increase disk I/O & CPU load](https://askubuntu.com/questions/367881/does-swap-file-usage-increase-disk-i-o-and-cpu-load). This is a tradeoff. Without swap, the OOM may get you. It causes a downtime and in the real life scenario, the application can be slow a bit rather than down completely. -### Swappiness +### Swappiness - The linux kernel tunable parameter `vm.swappiness` (/proc/sys/vm/swappiness) can be used to define how aggressively memory pages are swapped to disk. - The default value: `60`. The lower the value, the less swapping is used & the more memory pages are kept in the physical memory. @@ -70,7 +70,7 @@ swap <= 10% * total-size-hard-drives && swap <= 128GB (if hibernation is allowed - On SSDs, swapping out anonymous pages and reclaiming file pages are essentially equivalent in terms of performance/latency. On older spinning disks, swap reads are slower due to random reads, so a lower vm.swappiness setting makes sense there. -### Using swap as emergency memory +### Using swap as emergency memory - Swap is not generally about getting emergency memory, it's about making memory reclamation egalitarian and efficient. In fact, using it as "emergency memory" is generally actively harmful. diff --git a/content/posts/openstack-autoscaling-new-approach.md b/content/posts/openstack-autoscaling-new-approach.md index ffe43a3..095cd1c 100644 --- a/content/posts/openstack-autoscaling-new-approach.md +++ b/content/posts/openstack-autoscaling-new-approach.md @@ -14,7 +14,7 @@ This guide describes how to automatically scale out your Compute instances in re Let's talk about the standard OpenStack Autoscaling approach before goes to the new approach. -### Main components +### Main components - Orchestration: The core component providing automatic scaling is Orchestration (heat). Orchestration allows you to define rules using human-readable YAML templates. These rules are applied to evaluate system load based on Telemetry data to find out whether there is need to more instances into the stack. Once the load has dropped, Orchestration can automatically remove the unused instances again. @@ -23,11 +23,11 @@ Let's talk about the standard OpenStack Autoscaling approach before goes to the - Gnocchi: provides a time-series resource indexing, metric storage service with enables users to capture OpenStack resources and the metrics associated with them. - Aodh: enables the abiltity to trigger actions based on defined rules against sample or event data collected by Ceilometer. -### Autoscaling process +### Autoscaling process For more details, you could check [IBM help documentation](https://ibm-blue-box-help.github.io/help-documentation/heat/autoscaling-with-heat/) -### Drawbacks +### Drawbacks - Ceilometer, Aodh are lacking of contribution. Ceilometer API was [deprecated](https://review.opendev.org/#/c/512286/). Either Transform and pipeline was [the same state](https://review.opendev.org/#/c/560854/), it means cpu_util will be unusable soon. In the commit message, @sileht - Ceilometer Core reviewer wrote that "Also backend like Gnocchi offers a better alternative to compute them". But Aodh still [deprecated Gnocchi aggregation API](https://github.com/openstack/aodh/blob/master/aodh/evaluator/gnocchi.py#L140) which doesn't support `rate:mean`. For more details, you can follow the [issue I've opened before](https://github.com/gnocchixyz/gnocchi/issues/999). Be honest, I was gave up on it - 3 projects which was tightly related together, one change might cause a sequence and break the whole stack, how can I handle that? - Aodh has its own formula to define rule based on Ceilometer metrics (that were stored in Gnocchi). But it isn't correct sometimes cause the wrong scaling action. @@ -36,7 +36,7 @@ For more details, you could check [IBM help documentation](https://ibm-blue-box- ## The new approach with Faythe -### The idea +### The idea Actually, this isn't a complete new approach, it still leverages Orchestration (heat) to do scaling action. The different comes from Monitor service. @@ -57,7 +57,7 @@ The _another service_ is [Prometheus stack](https://prometheus.io/). The questio - Flexibile: Beside the system factor like CPU/Memory usage, I can evaluate any metrics I can collect, for example: JVM metrics. - // Take time to investigate about Prometheus and fill it here by yourself -### The implementation +### The implementation **The ideal architecture** @@ -143,7 +143,7 @@ We need a 3rd service to solve these problems - `Faythe does some magic`. - Prometheus alertmanager sends Alerts via pre-configured webhook URL - Faythe endpoint. - Faythe receives and processes Alerts (dedup, group alert and generate a Heat signal URL) and creates a POST request to scale endpoint. -### Guideline +### Guideline The current aprroach requires some further setup and configuration from Prometheus and Heat stack. You will see that it's quite complicated. @@ -304,7 +304,7 @@ server_config: