Mastro as a server on the command line
When generating a static site, the whole website is generated upfront. On the other hand, when on-demand rendering (which some people also call server-side-rendering or SSR), the HTML is generated anew on every request by the server. This comes at the cost of running a server, but enables you to send different pages to different users. When paired with a database like PostgreSQL (and perhaps a query builder like Kysely), Mastro can even serve as a full-stack framework.
In this chapter, weāll install Mastro as a development server on your laptop using the command line. In the next chapter, weāll see how to use this setup to deploy a statically generated site (like weāve done so far with the VSāCode extension, but this time with the command line), and also how to run Mastro as a production server doing on-demand server-side rendering.
Different ways to run Mastro
Hereās a table listing the various ways you can run Mastro. Either locally (meaning on your laptop or desktop), or on a production system in some data center, to host your live website. And either using VSāCode for Web in your browser, or by installing things and using the command line.
| Local development | Prod static site (SSG) | Prod server (SSR) | |
|---|---|---|---|
| VSāCode for Web (online) | Try or Setup | Publish static site | - |
| Command line | Setup local server | Deploy static site via CI/CD | Deploy server |
Setup local development server
In this section, weāll be using the modern Deno JavaScript runtime, which makes our life quite a bit easier compared to other runtimes. No messing with npm install and node_modules folders. And in Deno, niceties like TypeScript, Deno.serve, and a formatter are all built-in and pre-configured. However, you can also use Mastro with Node.js or with Bun, should you choose to do so.
To preview your website in a browser, while you work on it, letās start a local development server.
-
Open a terminal application on your computer, which will provide you with a command-line interface (CLI). On macOS, the pre-installed terminal app can be found under
/Applications/Utilities/Terminal. On Windows, you can use PowerShell, or for additional compatibility with Linux servers use WSL. -
Install Deno: the easiest way is by copy-pasting the following into your terminal:
curl -fsSL https://deno.land/install.sh | shCopied!and hit enter.
-
Navigate to the folder where you want to create your new project folder in, for example type:
cd DesktopCopied!and hit enter.
-
Then type (or copy-paste):
deno run -A npm:@mastrojs/create-mastro@latestCopied!and hit enter. This Mastro initalization script will ask you for a folder name for your new server project. Enter for example
test-serverand hit enter (folder names with spaces are a bit of a pain on the command-line). -
Then it will tell you to
cd test-server, and from there you can enter:deno task startCopied!This will start your server! You can see the dummy page itās serving by opening the following URL in your web browser: http://localhost:8000 (The
8000is the port. If youād want to run multiple web servers on the same machine, each would need to use a different port.)To stop the server again, switch back to the terminal and press
Ctrl-Con your keyboard.
To edit the files in the newly created folder, youāll want to install Visual Studio Code on your computer (or a similar code editor) and open the newly created project folder in it.
Check out the contents of the generated folder. Itās a bare-bones Mastro project, but now with:
- a
deno.jsonfile, which specifies the Mastro version to use, and what happens if you typedeno task startordeno task generate, - the
deno.lockfile, which remembers exactly which version of each package was used, - the
server.tsfile, which is executed to start up the server (here you might add customizations like middleware), and - the file in the
routes/folder is now calledindex.server.tsinstead ofindex.server.js, because itās TypeScript ā JavaScript with type annotations. This allowsdeno checkto find certain problems in your code even without running it.
Congrats, youāre all set now to work locally on your project.
Version control with Git
Just changing your projectās files on your computer will not change them on GitHub. To commit and push your changes, you can either:
- continue to use the Source Control view built into VSāCode,
- install a GUI like GitHub Desktop or Git Up, or
- use
giton the command line, see e.g. this cheat sheet.
Either way, in the long run it pays off to make the right mental model for Git.