What's new

SBS. Script for using sing-box on Asus routers with Merlin firmware.

  • SNBForums Code of Conduct

    SNBForums is a community for everyone, no matter what their level of experience.

    Please be tolerant and patient of others, especially newcomers. We are all here to share and learn!

    The rules are simple: Be patient, be nice, be helpful or be gone!

They don't come there. At least AGH doesn't see them.
So they never leave the router then. What if you do a dns lookup from your router to the linux server i.e:
Code:
dig @<linux server ip> google.com

If this works it would indicate that your issue is with singbox not forwarding requests locally or atleast not correct.

If it's not working there is still something in routing or firewall config.
 
So they never leave the router then. What if you do a dns lookup from your router to the linux server i.e:
Code:
dig @<linux server ip> google.com
-sh: dig: not found

Code:
nslookup google.com 192.168.50.30
Server:    192.168.50.30
Address 1: 192.168.50.30 ubuntu-first.RT-AX86U


Name:      google.com
Address 1: 142.250.74.78 arn09s23-in-f14.1e100.net
Address 2: 2a00:1450:400f:802::200e arn09s23-in-x0e.1e100.net
But, as I already said, I previously installed sing-box on a virtual Linux machine and from there it worked without problems with AGH on a home Linux server.
 
Last edited:
New update for SBS (sing-box-script).
To install the script, run this command on the router command line
Code:
wget -O /jffs/scripts/sbs https://raw.githubusercontent.com/Dr4tez/sing-box4asus/main/sbs && chmod 775 /jffs/scripts/sbs && /jffs/scripts/sbs install
1. Support for simultaneous operation of up to two TUN interfaces. This will be useful if, for example, you want to direct the traffic of some devices through sing-box according to the rules specified in the sing-box configuration file, while directing the traffic of other devices entirely to the proxy tunnel.
2. Added command:
Code:
sbs check
This function is built into the sing-box core and is used to check the correctness of the sing-box configuration file (config.json). It does not detect all errors, but in most cases, it helps a lot in finding them. As a result, it shows the first found error with its line and column number in config.json. Then, to fix the error, you are prompted to open config.json in the nano editor. After fixing and finishing editing, the next error, if any, is found, and you are again prompted to fix it in the nano editor. This repeats until you fix all errors or decide to stop by refusing to edit the next error.
3. Added command:
Code:
sbs format
This function is built into the sing-box core and is used to give config.json a readable structure as intended by the sing-box developer. First, like sbs check, the sbs format command checks config.json for errors. If errors are found, formatting will be impossible until you fix them all. After fixing all errors, the configuration file structure will be optimized, the result will be displayed in the console, and you will be prompted to save it to your config.json.
4. Minor bug fixes.

To upgrade from version 0.6 or 0.5 to version 0.7:
Save your config.json file located in the /jffs/addons/sing-box-script directory (this directory will be deleted along with the /opt/root/sing-box directory).
Remove version 0.6 or 0.5 using the command in the router's console:
Code:
sbs remove
Install version 0.7 by running the following command in the router's console:
Code:
wget -O /jffs/scripts/sbs https://raw.githubusercontent.com/Dr4tez/sing-box4asus/main/sbs && chmod 775 /jffs/scripts/sbs && /jffs/scripts/sbs install
Set up the script with the command in the router's console:
Code:
sbs setup
At this point, you can edit the new preset config.json template or edit your config.json after placing it in the /jffs/addons/sing-box-script directory, as it is now possible to use two TUN interfaces simultaneously, and the template has been slightly modified for this purpose.
 
Just finished another update of my script for downloading, installing, configuring and running sing-box on Asus routers with Merlin firmware.
Updated 08/04/2024. Version v0.8
Added the command
Code:
sbs status
which shows whether sing-box is running, as well as the versions of the installed SBS script and sing-box core.

To update from version 0.7 to version 0.8, run the following command in the router's command line:
Code:
sbs update
To install the script, run this command in the router's command line:
Code:
wget -O /jffs/scripts/sbs https://raw.githubusercontent.com/Dr4tez/sing-box4asus/main/sbs && chmod 775 /jffs/scripts/sbs && /jffs/scripts/sbs install
 
Last edited:
Another update of my script for downloading, installing, configuring and running sing-box on Asus routers with Merlin firmware.
Updated 08/09/2024. Version v0.9

Changes:

1. Fixes for discovered issues.
2. Added support for routers with ARMv7/AArch32 processor architecture. Previously, only ARMv8/AArch64 architecture was supported.

To upgrade from version 0.8 to version 0.9:
1. Save your configuration file config.json located in the /jffs/addons/sing-box-script directory (it will be deleted, along with the /opt/root/sing-box directory).
2. Remove version 0.8 by running the following command in the router's command line:
Code:
sbs remove
3. Install version 0.9 by running the following command in the router's command line:
Code:
wget -O /jffs/scripts/sbs-ru https://raw.githubusercontent.com/Dr4tez/sing-box4asus/main/sbs-ru && chmod 775 /jffs/scripts/sbs-ru && /jffs/scripts/sbs-ru install
4. Place your saved config.json file in the /jffs/addons/sing-box-script directory.
5. Configure the script by running the following command in the router's command line:
Code:
sbs setup
 
Again updating my script for downloading, installing, configuring and running sing-box on Asus routers with Merlin firmware.
Updated 08/13/2024. Version v1.0

Changes:

1. The output of the 'sbs status' command now includes the sing-box core architecture and the router's CPU architecture.
2. For devices whose traffic is routed through sing-box, the script now adds routing rules to the system that direct their local traffic to bypass sing-box. This improves the interaction of these devices with each other and with other devices on the local network.
3. Improved the logic of the sbs-monitor script.

To upgrade from version 0.9 to version 1.0, run the
Code:
sbs update
command in the router command line.
 
The latest update of my script for downloading, installing, configuring, and running sing-box on Asus routers with Merlin firmware.
Updated 08/23/2024. Version v1.1

Changes:

1. The routes and routing rules created by the script have been optimized.
2. A simpler and more reliable method for removing the routing tables created by the script at startup has been implemented when the script is stopped.
3. The 'sbs update' command now presents a menu that allows you to select components for updating and displays their installed and available versions.
4. Now, when configuring the script with the 'sbs setup' command, you can enter the entire subnet of the router in the field for device IP addresses. The only downside to this is that access to the router's web interface from the WAN will be lost if it is allowed in the router settings. Additionally, access from the WAN through port forwarding to other devices on the router's network will also be lost. However, this was already the case for all devices whose IP addresses were entered during the script setup.

To upgrade from version 0.9 or 1.0 to version 1.1, run the
Code:
sbs update
command in the router command line.
 
Last edited:
Another update of my script for downloading, installing, configuring and running sing-box on Asus routers with Merlin firmware.
Updated 09/01/2024. Version v1.2

Changes:

1. A separate menu has been created for script configuration, which can be accessed using the
Code:
sbs setup
command. In this menu, functions previously performed by the single 'sbs setup' command have been separated: adding device IP addresses and changing routing table numbers. Additionally, the menu now includes the option to edit the script's settings file using the nano editor, which was previously done with the separate 'sbs edit' command.
2. In the script configuration menu, when adding a subnet in CIDR format as a device's IP address (e.g., 192.168.50.0/24), the next step prompts you to enter exception IP addresses.
3. A separate menu has been created for configuring the sing-box configuration file, accessible via the
Code:
sbs edit
command. This menu combines functions previously performed by separate commands: checking the sing-box configuration file for errors and optimizing its structure. Additionally, this menu now includes the option to edit the sing-box configuration file using the nano editor, which was previously offered during the execution of the 'sbs setup' command.
4. The main script and the sbs-monitor script have been improved to correctly add, remove, and restore rules and routes, taking into account subnets and exceptions.
5. Code optimization and adjustments to command line output messages.

Due to the addition of new functionality, it is not possible to update to version 1.2 correctly using the 'sbs update' command. Therefore, to upgrade from previous versions to version 1.2:
1. Save your configuration file config.json from the /jffs/addons/sing-box-script directory somewhere safe.
2. Remove the previous version by running the command
Code:
sbs remove
in the router's command line.
3. Install version 1.2 by executing the following command in the router's command line:
Code:
wget -O /jffs/scripts/sbs https://raw.githubusercontent.com/Dr4tez/sing-box4asus/main/sbs && chmod 775 /jffs/scripts/sbs && /jffs/scripts/sbs install
4. Place your saved configuration file config.json back into the /jffs/addons/sing-box-script directory.
5. Configure the script by running the
Code:
sbs setup
command in the router's command line.
 
Curious is this now working as you wanted it to? Am in restricted country as well, China. Have been able to use singbox apps mostly android, use hiddify on windows but using a subscription to an outside VPS server somehow everything that runs through singbox always works the best, everything seems to be optimized for hopping over the wall. Also been using the Merlin fork Clash with the VPS service which mostly works fine but has it's own complications DNS which is beyond my skill level. Was curious about installing just Singbox on my router as singbox just seems to work almost without problems in my situation
 
Curious is this now working as you wanted it to? Am in restricted country as well, China. Have been able to use singbox apps mostly android, use hiddify on windows but using a subscription to an outside VPS server somehow everything that runs through singbox always works the best, everything seems to be optimized for hopping over the wall. Also been using the Merlin fork Clash with the VPS service which mostly works fine but has it's own complications DNS which is beyond my skill level. Was curious about installing just Singbox on my router as singbox just seems to work almost without problems in my situation
Everything works the way I need it to, at least for me.
Read the readme in the first post of the topic, some nuances are described there. In China, perhaps censorship is stricter, and therefore problems with DNS requests are possible. Try it, the script and all its tails are removed as easily as they are installed, with just one command.
 

Latest threads

Support SNBForums w/ Amazon

If you'd like to support SNBForums, just use this link and buy anything on Amazon. Thanks!

Sign Up For SNBForums Daily Digest

Get an update of what's new every day delivered to your mailbox. Sign up here!
Top