In this article, I’ll show you how to quickly use Flare, a lightweight, aesthetically pleasing, privacy-first, 100% data-controlled bookmark navigation tool in Docker.
If you’re familiar with Docker, you’ll have your own bookmark navigation in 10 minutes. If you’re a beginner, it doesn’t matter. Follow this article step by step, and in about half an hour, you’ll be able to get Flare running inside Docker, stepping into the container world.
Writing in the front
At the beginning of my last article, Docker for HomeLab, I mentioned some of my past experiences with the bookmark navigation tool: Over the past decade or so of Chrome, thousands of bookmarks have slowly made their way into bookmarks, and then slowly gathered dust, just like the books in the actual bookcase.
A few months ago, I started a personal PKM rebuild, one of which was about bookmark usage. To be honest, I’m not particularly happy with the current bookmarking program for several reasons:
I wanted this tool to be more efficient and simple, rather than having very little content displayed in the bookmarks bar and more content to be found through layers of “folders,” or by taking a chance in the search bar to see if keywords and autocomplete can match specific content. Guessing and rummaging is a waste of time.
I wish the data were privatized and less uncertain. As a “young man” who has used all kinds of Internet products for more than 20 years, I have seen too many tools and companies rise and fall. The companies behind many online services and software are slowly becoming a grain of sand in the long run, and users’ data is often buried as products and companies fall apart. The data disappears with the product, which I don’t want to see.
I want the software to be generic and bookmark data not to play with the browser’s reproductive isolation. Tools and add-ons that work only in Chrome, or only in Safari or Internet Explorer, always give me the feeling that my data has been kidnapped. Even though I only use Chrome most of the time, I still want to be able to “point” at my bookmarks when I open Safari and get to where I want to go quickly. (I have some reservations about the ability to import bookmarks between browsers, because of the “bookmark chaos” and “bookmark shadow” incidents that occurred when I migrated between Chrome, Firefox and domestic browsers.)
After experimenting with a variety of software, I settled on a polish programmer’s project (Flame). After digging into the software, refactoring some of the code, packaging the container application, and submitting a few PR’s. I figured out what I wanted, so I went ahead and built a gadget that looked exactly like Flame: a bookmark navigation tool with higher performance, more transparent data and easier to use.
Before I talk about how to use it, I’m sure you’re more curious, what’s so good about it?
The advantage of the Flare
Flare’s biggest advantage is the sheer performance advantage of having the same beautiful interface as Flame: Whether it’s a container image size of less than 10M, memory consumption of less than 30M during normal operation, or page opening in 99% of the time (tens of thousands of bookmarks) without triggering the fan frenzy of devices like laptops.
As “fast” is Flare’s main advantage, the front end of the application naturally needs a few “full marks” to make things happen.
Here are two small intuitive examples: Use a test tool to test the pressure (stability) of millions of requests against Flare without any configuration adjustments, and you can still open the page and use it in 1-2 ms while maintaining 4800 to 5000 concurrent requests per second (limit, memory usage is 60 MB, It usually stabilizes around 30M); And the Flare can even run on an ARM case with a 2015 S805 chip (which costs about $50).
# Simple stress test example
wrk -t16 -c 100 -d 300s http://localhost:5005/
Running 5m test@http://localhost:5005/ 16 threads and 100 connections Thread Stats Avg Stdev Max +/- Stdev Latency 29.9ms 33.99ms 619.31 MS 85.99% Req/Sec 302.64 84.43 710.00 69.26% 1446450 requestsin5.00 m, 33.70 GBread
Requests/sec: 4819.96
Transfer/sec: 114.99MB
Copy the code
Flare has a simpler and more transparent data strategy, using text format to store bookmarks, whether it’s in the distant future when applications don’t work on current hardware or operating systems, or when we have to switch software; Whether you use Flare and find a tool that fits your own aesthetic better, you can migrate data at a fraction of the cost. “Users’ data should be their own”, at least I think so.
Everyone must have different requirements for beauty, but if the style and quality of the bookmark icon we use is highly consistent, then the software interface is still “more able to play, and can play for a long time” (personal use of the software interface bottom line, at least be durable). Here I found and customized dozens of simple weather Icons, and integrated over 6,000 Material Design Icons into the software to make them easy to use “out of the box”. Refer to this document for details on how ICONS are used.
Flare is also cheaper to use than Flame, a common weather presentation feature. Usually all you have to do is launch the software, and it gets the necessary weather data at a very restrained rate, with as little setup as possible (thanks to the geolocation interface provided by IPIP.net). This is currently Flare’s only networking function. You can disable Flare’s networking by enabling “offline mode”, or refer to this Issue reply to complete a complete and complete network shutdown for container applications, fundamentally addressing privacy concerns. In the latest version, the application also supports the use of external image addresses, or has the application grab ICONS directly from the target linked site, to make links on the page more distinct.
Of course, in order to take care of the editing needs of some friends anytime and anywhere, the latest version of the update, also added online editing function.
Next, let’s see how to use it. Of course, there are a few minor details that are left to the curious to explore.
Quick initialization of the Docker environment
Currently, Flare downloads and security are done using Docker. If you are a Mac or Windows user, you can download and install the desktop version of Docker to initialize the base runtime environment.
If you are a beginner to Linux, consider using a simple script I created to quickly install and initialize Docker and the common tool Docker-compose. If your server is overseas, you can use the following command to quickly complete the environment installation:
curl -sL https://github.com/soulteary/Home-Network-Note/raw/master/scripts/install-docker.sh | bash
curl -sL https://github.com/soulteary/Home-Network-Note/raw/master/scripts/install-compose.sh | bash
Copy the code
If your environment is in China, run the following command and install the environment according to the log output:
curl -sL https://github.com/soulteary/Home-Network-Note/raw/master/scripts/install-docker-cn.sh | bash
curl -sL https://github.com/soulteary/Home-Network-Note/raw/master/scripts/install-compose-cn.sh | bash
Copy the code
The above installation script, I uploaded to GitHub, there is a need for small partners can help: github.com/soulteary/H… .
Quickly install and use Flare
Flare can be used in a number of ways, but I’ll go through all of them in the interest of sustainability.
Let’s start with the simplest solution. (Small reminder from the author, the following scheme, according to the personal situation to choose a convenient can be)
HelloWorld: Quick trial Flare with Docker
With the Docker environment in place, we can start the Flare with a simple command:
docker run --rm -it -p 5005:5005 -v `pwd`/app:/app soulteary/flare
Copy the code
When the command is executed, we should see log output similar to the following:
INFO[2022-02-23T19:08:43+08:00] Flare V0.3.1-85EED66 Linux/AMd64 BuildDate=2022-02-23T10:22:43+0800 INFO[2022-02-23T19:08:43+08:00] INFO[2022-02-23T19:08:43+08:00] Program service port 5005 INFO[2022-02-23T19:08:43+08:00] page request mergefalseINFO[2022-02-23T19:08:43+08:00] Enables offline modefalseINFO[2022-02-23T19:08:43+08:00] Login mode is disabled. Users can directly adjust application Settings. INFO[2022-02-23T19:08:43+08:00] The online editing module is enabled. You can visit/Editor to get help using the program. INFO[2022-02-23T19:08:43+08:00] The wizard module is enabled. You can visit/Guide to get help using the program. INFO[2022-02-23T19:08:43+08:00] the program has been started 🚀Copy the code
At this point, open http://localhost:5005 in your browser and see the bookmark navigation page above.
If we look at the directory where the above command was executed, we will find several “extra” files in the folder:
├── ├─ exercises, exercises, exercises, exercises, exercises, exercisesCopy the code
These files are the “application bookmarks”, “classification bookmarks” and “application configuration” data files, except config.yml can be deleted at will, the other two files save your bookmarks data, please take care to save and backup.
If we open any bookmark data file, we should see something like the following:
links:
- name: The sample link
link: https://link.example.com
icon: evernote
desc: Link description text
- name: The sample link
link: https://link.example.com
icon: FireHydrant
desc: Link description text
- name: The sample link
link: https://link.example.com
icon: email
desc: Link description text
.
Copy the code
Yes, links in Flare are stored in this format, simple “text files” that you can edit in any way you like, and save the data in any way you like. When you modify this file to suit your needs, the Flare content will update synchronously after you refresh the browser page.
If you want the software to run in the background, or if you want the software to run on another port, such as listening on 8080, you can change the running parameter to:
docker run --rm -d -p 8080:5005 -v `pwd`/app:/app soulteary/flare
Copy the code
Run the Flare using Docker-compose
Docker-compose allows us to run container applications (such as flare) based on explicit configuration files and fine-grained Settings of application functionality without having to remember cumbersome parameters, as shown in a simple example below.
version: '3.6'
services:
flare:
image: soulteary/flare
restart: always
command: flare
ports:
- 5005: 5005
volumes:
- ./app:/app
Copy the code
This configuration takes about ten lines of code to specify flare images, flare startup commands, open ports, map data files, and process daemons that automatically restart when problems occur.
Docker-compose configuration file: docker-compose configuration file: docker-compose configuration file: docker-compose configuration file: docker-compose
version: '3.6'
services:
flare:
image: soulteary/flare
restart: always
No need to add any parameters by default, if there are special requirements
https://github.com/soulteary/docker-flare/blob/main/docs/advanced-startup.md # can read document
command: flare
Enable account login mode
# command: flare --nologin=0
# environment:
Set the 'nologin' startup parameter to '0' if you want to enable user login mode
# If 'nologin' is enabled and FLARE_USER is not set, the default user is' flare '
# - FLARE_USER=flare
# specify your own password. If 'FLARE_USER' is not set, the password will be generated by default and displayed in the app startup log
# - FLARE_PASS=your_password
# Whether to enable the 'Use Wizard', visit '/guide'
# - FLARE_GUIDE=1
ports:
- 5005: 5005
volumes:
- ./app:/app
Copy the code
We’ll save the above file as docker-compose. Yml and use docker-compose up -d. After a while, again use your browser to visit http://localhost:5005 and unsurprisingly you’ll see flare’s neat interface.
Use Flare with Traefik
Many of my regular readers are Traefik users, so here are the container choreography configurations for Traefik.
If you have experience with Docker-compose, nginx, then I recommend you try Traefik. Once you are familiar with it, you will open up a new world. If you haven’t played it yet, check out this project to get started quickly: github.com/soulteary/t… Or read my past articles that cover the techniques Traefik uses.
# Traefik quick learning and use, may refer to https://github.com/soulteary/traefik-example/
version: '3.6'
services:
flare:
image: soulteary/flare
restart: always
No need to add any parameters by default, if there are special requirements
https://github.com/soulteary/docker-flare/blob/main/docs/advanced-startup.md # can read document
command: flare
labels:
- "traefik.enable=true"
- "traefik.docker.network=traefik"
- "traefik.http.routers.traefik-flare-http.middlewares=https-redirect@file"
- "traefik.http.routers.traefik-flare-http.entrypoints=http"
- "traefik.http.routers.traefik-flare-http.rule=Host(`flare.example.com`)"
- "traefik.http.routers.traefik-flare-http.service=dashboard@internal"
- "traefik.http.routers.traefik-flare-https.entrypoints=https"
- "traefik.http.routers.traefik-flare-https.rule=Host(`flare.example.com`) && PathPrefix(`/`)"
- "traefik.http.routers.traefik-flare-https.tls=true"
- "traefik.http.services.traefik-flare-backend.loadbalancer.server.scheme=http"
- "traefik.http.services.traefik-flare-backend.loadbalancer.server.port=5005"
networks:
- traefik
expose:
- 5005
volumes:
- ./app:/app
networks:
traefik:
external: true
Copy the code
The usage is still simple docker-compose up -d, and once the container is up and running, the browser directly visits the domain name we dynamically registered in Traefik, in this case flare.example.com.
Although there are so many ways to install.
However, I’m guessing you’re still confused about Flare at the moment, so let’s take a closer look at Flare’s features and interface.
Learn more about Flare
Considering that a text introduction would take a lot of space, I created a simple wizard to quickly read the introduction of feature points in about ten seconds.
So, how do YOU open Flare’s wizard? Just behind the address bar of the original plus/guide, like this: http://localhost:5005/guide, is very simple.
Next, talk about expanding the topic.
Use Flare on public network servers
Although Flare by default runs in stand-alone mode, it does not require a “user login”. But some partners hope that the software can run on cloud servers, for example, to make the “lightweight cloud”, which has been eating dust for a long time, come to life.
At this point, it would be a lot of trouble if anyone could change the app Settings. So we can adjust the application’s custom startup parameters to disable “login free mode”.
flare --disable_login=0
Copy the code
By default, the application uses the flare account name and a randomly generated admin password. If we want to log in with our own specific account and password, we can do this by setting FLARE_USER and FLARE_PASS in the environment variable, To replace the flare’s default login account and random password, using the Docker-compose file as an example:
version: '3.6'
services:
flare:
command: flare --disable_login=0
.
Copy the code
Isn’t that easy? For a complete configuration, see the following:
version: '3.6'
services:
flare:
image: Soulteary/flare: 0.2.7
restart: always
No need to add any parameters by default, if there are special requirements
https://github.com/soulteary/docker-flare/blob/main/docs/advanced-startup.md # can read document
Enable account login mode
command: flare --disable_login=0
environment:
Set the 'nologin' startup parameter to '0' if you want to enable user login mode
# If 'nologin' is enabled and FLARE_USER is not set, the default user is' flare '
- FLARE_USER=flare
# specify your own password. If 'FLARE_USER' is not set, the password will be generated by default and displayed in the app startup log
- FLARE_PASS=your_password
ports:
- 5005: 5005
volumes:
- ./app:/app
Copy the code
Docker-compose ps: docker-compose ps: docker-compose ps: docker-compose ps: docker-compose PS
INFO[2022-02-23T19:10:07+08:00] Flare V0.3.1-85EED66 Linux/AMd64 BuildDate=2022-02-23T10:22:43+0800 INFO[2022-02-23T19:10:07+08:00] INFO[2022-02-23T19:10:07+08:00] Program service port 5005 INFO[2022-02-23T19:10:07+08:00] page request mergefalseINFO[2022-02-23T19:10:07+08:00] Enable offline modefalseINFO[2022-02-23T19:10:07+08:00] To enable the login mode, you need to log in before adjusting the application Settings. INFO[2022-02-23T19:10:07+08:00] DEFAULT INFO[2022-02-23T19:10:07+08:00] user not specified 'FLARE_USER', With the default username flare INFO[2022-02-23T19:10:07+08:00] users do not specify 'FLARE_PASS', Automatic generation of application password DD0624b7 INFO[2022-02-23T19:10:07+08:00] Online editing module enabled, you can access/Editor to get help using the program. INFO[2022-02-23T19:10:07+08:00] The wizard module is enabled. You can visit/Guide to get help using the program. INFO[2022-02-23T19:10:07+08:00] Program has been started 🚀Copy the code
The next step is to log in to the app and set it up. I’ll leave it to you to explore and play with.
If you want to be more private, use flare –disable_login=0 –visibility=private to set your home page content to be visible to the login.
Other information
If you’re interested in the process of making Flare, you can check out Flare’s Making Notes: Optimizing The Performance of the Front and back End of your Application for some ideas and details.
In addition, to make it easier for you to use and adjust Flare, you can also refer to the following documentation:
- Flares – Custom Startup Parameters
- How to Set a User Account after the Sign-on Free mode is Disabled
- How to Pick and Use ICONS
- How to Use it with Traefik
The last
If you think this project has helped you, please like and retweet this article, so that other people can see it (the more users feedback, the faster the update).
If you’re a code buff, you can also give the producer a little encouragement by liking the project ✨ (star) on GitHub; If you want to receive the update push of this project, it is recommended to click the GitHub project to follow 👀 (watch) and select the appropriate mode of attention. It is recommended to choose the release mode. Once a new version appears, you will be reminded of the push in the first time.
Of course, you’re more than welcome to comment on my main hangouts and improve Flare’s experience together.
–EOF