I am a 40+ software engineer and recreational Jiu Jitsu practitioner, struggling with vast amount of information related to the sport. I decided to make use of my `computer` skills to aid me in the process of taming this new skill.
In this section I am going to discuss why and how markdown is the ideal format for using for your notes. I am also going to conver how to use markdown in order to maintain wiki/second brain for your Jiu Jitsu notes.
Markdown is a lightweight markup language for creating formatted text using a plain-text editor. Formatting includes things like:
- Headers
- Bold, italic, underlined text
- Images
- Hyperlinks
- Tables
If you know what html is, you can think of markdown as an alternative to html that instead of weird tags, just makes clever use of symbols.
Here is an example:
# Heading
## Sub-heading
Unordered list:
- item 1
- item 2
- item 3
| Syntax | Description |
| ----------- | ----------- |
| Header | Title |
| Paragraph | Text |
It is 100% pure text. No propriatory file formats, no coupling to a particular editor or tool. You can easily edit it from all your devices without the need of any specialized software.
This also means that you can easily generate or manipulate it using scripts (cough cough). This is really important because we can easily export information from instructionals directly into markdown.
For example, we can generate an animated gif, as demonstrated in previous posts and embed the image into markdown (e.g. see my notes on ‘Double Under’).
Most importantly, markdown supports links, which is what makes using markdown for building ourselves a second brain (interconnected notes).
After searched for a proper definition in multiple wiki pages, I came up with:
`Wiki is a knowledge base presented as collection of well connected web pages and colaboratively edited.`
A richer definition can be found in wikipedia: wiki.
In this serires of posts we don’t really care about the collaborative part, but more about the edited that implies that a wiki is something living/evolving, that is expected to be edited / updated.
When I first started taking notes on Jiu Jitsu, I used a single text file, were I kept things. As the file grew larger, it was becoming harder and harder to easily jump to a particular note in the file. Also, there were cases were I needed to link notes together …
Think for a moment Juji gatame (armbar). How does one organize notes on juji gatame?
- Do they go in the attacks from mount section?
- Do they go in the attacks from closed guard section?
- Do they go in the flying attacks?
- Do they go in the escapes from popular attacks?
I think that it should go everywhere. And the only pragmatic way for this to happen is by linking `juji gatame` to all of the sections listed above.
When it comes to note taking, anything that can’t be represented by a single tree-like structure and contains links for one topic to another is better split per topic and use linking to bring pieces together.
This alone is enough for one to pickup wiki. Additional points for familiarity. And most importantly it is something that can be easily combined with markdown that is already mentioned above.
Have a look at my demo wiki, to get some idea:
This is not my complete wiki but something that I put together for the shake of this post (with hopefully enough teasers inside). It includes:
- Chunks of my personal notes
- Flow chart diagrams (for techniques) that I created myself (and yes, I will blog about how you can create them too).
- An animated gif or two that summarize techniques
This might also be a nice starting point for your own wiki, if you are sold on the idea.
Next step is to pick ourselves up the right tool for the job. Below there are the top three candidates:
Github is a git hosting service.
*Oversimplification alert*
Think of it as service that allows you to create public or private shared folders, that contain textual (mostly) and binary files. The service also keeps history of changes and provides a platform for collaboration with others. I wouldn’t suggest it to people not already familiar with git.
My demo wiki is hosted on Github, so you get the idea.
A wiki solution, that allows users to host their wiki either locally or publicly. It’s pretty extensible and one of the extensions provides markdown support. Even thought it seems pretty powerful, the installation of extensions proved to be a little bit tricky for me, so I wouldn’t recommend it either.
mdwiki (as the namely implies) is a markdown based wiki. I found it pretty simple to install and use and it’s what I recommend to use in this post. Note: This solution is not standalone and does require the use of an http server (see below).
Go to mdwiki releases page and grab the latest release zip file. At the time of writing this was mdwiki-0.6.2.zip Extract the contents of the zip in the folder you wish to save your notes.
On most systems, something like this would work.
unzip mdwiki-0.6.2.zip
Or use whatever you already use for extracting zip archives.
We will need an http server to serve our wiki.
On machines with nodejs already installed the easiest solution is to install http-sever via npm.
npm install -g http-server
If you don’t have nodejs installed, then follow the operating system specific options.
On windows you can just use the simple http server or any other server of your choice. Just install the application and select the mdwiki folder as the server root.
Assuming that you have your wiki files under `wiki` in your home directory, you could try:
http-server wiki
or in general
http-sevrver /path/to/wiki
Maybe this whole series should have started with post on docker but it didn’t. So, I’ll just through here a few words on docker and how to use it to run your wiki.
I’ll try to explain docker with as little technical details possible.
Imagine the following use cases:
- You want to run an application without installing it locally.
Why ?
- To quickly try out the application
- To use a different version of the application you have currently installed.
- To avoid having to deal with installing required software
- Security related reasons
- You want to run application that is not installable on your Operating System.
- You want to package multiple binaries / apps and configuration in a single bundle.
- You want something like a virtual machine, but:
- Easier to create
- Smaller
- With faster startup
So, docker is a possible solution for the use cases described above.
If you already have docker installed on your machine and don’t fancy dealing with how to install a webserver to run your wiki, look no futher.
docker run -d -p 80:8080 -v ~/wiki:/wiki iocanel/http-server:09.2021 /wiki
Just open your browser at `http://localhost` and you should be good to go.
From this point on you can start using your wiki and fill it with notes.
I won’t spent time explaining the sytax. I’ve already provided a links to guides markdown docs. (every occurance markdown is a link to https://www.markdownguide.org/). I also use from time to time this cheatsheet. In any case, the syntax is pretty trivial and this is why its recommended.
You will be able to catch up with syntax pretty fast, but it might take you a while before you find how to best organize your notes.
I found that what works best for me is to keep each note as small and focused as possible. This allows me to better link pieces together in meanigful way. Have a look at my demo wiki to get ideas, or even use it as a starting template for your wiki.
Also, I am really interested in knowing if how you organize your notes, so feel free to reach out to me and share your experiences, either by commenting, email etc.
- 01. Hackers guide to Jiu Jitsu: intro wordpress version github version
- 02. Hackers guide to Jiu Jitsu: ffmpeg wordpress version github version
- 03. Hackers guide to Jiu Jitsu: mplayer wordpress version github version
- 04. Hackers guide to Jiu Jitsu: markdown wiki wordpress version github version
- 05. Hackers guide to Jiu Jitsu: flowcharts wordpress version github version