Files
bitburner-src/src/Documentation/doc/en/basic/scripts.md
2025-11-05 14:05:31 -08:00

7.9 KiB

Before you start

It is highly recommended that you have a basic familiarity with programming concepts like for/while loops, conditionals like if/else, functions,arrays and variables before starting to write scripts - but you can start with basic skills and learn with practice.

If you'd like to first learn a bit about programming, see this page.

Scripts

Scripts you write in Bitburner are real, working JavaScript and can be used to automate basic hacking logic, and almost any mechanic in the game.

Running any script requires in-game RAM, with a minimum cost of 1.6 GB per script. More complex scripts and API functions generally require more RAM, which you will gain in many ways. Scripts can be run on any server you have root access to, but not all servers you find will have useable RAM.

How Scripts work offline

Being actual JavaScript, Bitburner also contains some quirks and limitations. For this reason, it is not possible for Bitburner scripts to run the same way at all times. However, you will continue to earn money and exp when Bitburner is not running, though at a slower rate. See How Scripts Work Offline for more details.

Identifying a Script

Many commands and functions target other scripts running on the same or a different server. Therefore, there must be a way to specify which script you want to affect.

One way to identify a script is by its unique PID (Process IDentifier). A PID number is returned from ns.run(), ns.exec(), etc; and is also shown in the output of ns.ps().

A second way to identify scripts is by filename, hostname and arguments. However, you will probably run multiple copies of a script with the same arguments, so this method is not necessarily unique to a script. In case of multiple matches, most functions will return an arbitrary one (typically the oldest).

If searching by filename, arguments must be an exact match - both the order and type of the arguments you supply matter.

Referencing Other Scripts

In order to reference a file, functions require the full absolute file path. For example

ns.run("/scripts/hacking/helpers.myHelperScripts.js");
ns.rm("/logs/myHackingLogs.txt");
ns.rm("thisIsAFileInTheRootDirectory.txt");

A full file path must begin with a forward slash (/) if that file is not in the root directory. For details on references in terminal commands, see Terminal.

Script Arguments

When running a script, you can use flags and arguments, which the script's logic can access and act on, allowing flexibility in your script designs. For example allowing you to get different results or attack different targets without re-writing your code:

$ run hack.js "harakiri-sushi"
$ run hack.js "silver-helix"

Multithreading scripts

A script can be run with multiple threads, which we call "multithreading." Multithreading affects every call to the ns.hack(), ns.grow(), and ns.weaken() methods, multiplying their effects by the number of threads used. For example, if a script run with 1 thread is able to hack $10,000, then running the same script with 5 threads would hack $50,000.

[Note -- Scripts will not actually become multithreaded in the real-world sense - Javascript is a "single-threaded" coding language.]

When "multithreading" a script, the total RAM cost can be calculated by simply multiplying the RAM cost of a single instance of your script by the number of threads you will use. [See ns.getScriptRam() or the mem terminal command detailed below]

Never-ending scripts

Sometimes it might be necessary for a script to never end and keep doing a particular task. In that case you would want to write your script in a never-ending loop, like while (true).

However, if you are not careful, this can crash your game. If the code inside the loop doesn't await for some time, it will never give other scripts and the game itself time to process.

To help you find this potential bug, any while (true) loop without any await statement inside it will be marked. A red decoration will appear on the left side of the script editor, telling you about the issue.

If you are really sure that this is not an oversight, you can suppress the warning using the comment // @ignore-infinite directly above the loop.

Working with Scripts in Terminal

Here are some terminal commands you will find useful when working with scripts:

check [script] [args...]

Prints the logs of the script specified by the name and arguments to Terminal. Remember that scripts are uniquely identified by their arguments as well as their name, and Arguments should be separated by a space. For example, if you ran a script foo.js with the argument foodnstuff then in order to 'check' it you must also add foodnstuff as an argument for the check command:

$ check foo.js foodnstuff

free

Shows the current server's RAM usage and availability

kill [pid] or kill [script] [args...]

Stops a script that is running with the specified PID, or script name and arguments. Remember that scripts are identified by their arguments as well as their name, and Arguments should be separated by a space. For example, if you ran a script foo.js with the arguments 1 and 2, then just typing kill foo.js will not work. Instead use:

$ kill foo.js 1 2

mem [script] [-t] [n]

Check how much RAM a script requires to run with "n" threads

$ mem [scriptname] -t n
$ mem hack.js -t 500

nano [script]

Create/Edit a script. The name of a script must end with a script extension (.js, .jsx, .ts, .tsx). You can also create a text file with a text extension (.txt, .json, .css).

ps

Displays all scripts that are actively running on the current server

rm [script]

Permanently delete a script from the server. Can only be undone with a save import.

run [script] [-t] [n] [args...]

Run a script with n threads and the specified arguments. Each argument should be separated by a space. Both the thread count and arguments are optional. If neither are specified, then the script will be run with a single thread and no arguments.

Examples:

Run foo.js single-threaded with no arguments::

$ run foo.js

Run foo.js with 10 threads and no arguments:

$ run foo.js -t 10

Run foo.js single-threaded with three arguments: [foodnstuff, sigma-cosmetics, 10]:

$ run foo.js foodnstuff sigma-cosmetics 10

Run foo.js with 50 threads and a single argument: foodnstuff:

$ run foo.js -t 50 foodnstuff

tail [pid] or tail [script] [args...]

Displays the logs of the script specified by the PID or filename and arguments. Remember that scripts are identified by their arguments as well as their filename. For example, if you ran a script foo.js with the argument foodnstuff, in order to tail it you must also add the foodnstuff argument to the tail command as so:

$ tail foo.js foodnstuff

top

Prints all scripts running on the server and their RAM usage.

$ top