Writing a Backend Service in TypeScript¶
TypeScript is the recommended language for writing backend services. It is a superset of JavaScript that adds static typing and other features that make it easier to write and maintain code.
Prerequisites¶
To write a backend service in TypeScript, you should be familiar with JavaScript and (ideally) TypeScript. Overall, basic JavaScript knowledge will be sufficient to get started, but async
/await
and Promises are used extensively for services, so you should be familiar with these topics.
Deno¶
Deno is a JavaScript/TypeScript runtime that is built on top of V8, Rust, and Tokio. It is a secure runtime for JavaScript and TypeScript.
Compared to Node.js, Deno has the following advantages:
- It has built-in TypeScript support
- It has built-in security features
- It’s easier to deploy
Installing Deno¶
To install Deno, please follow the instructions on the Deno website .
Writing a basic Service¶
Creating a new Service¶
Create a new directory for your service:
Create a new file called service.ts
:
Writing the Service¶
Open service.ts
in your favorite editor and add the following code:
import { startService } from 'https://deno.land/x/telestion/mod.ts';// (1)!
await startService/*(2)!*/({
nats: false,// (3)!
});
console.log('Hello World!');// (4)!
- Import the
startService
function from the library. - Start the service. This automatically connects to NATS and does some other setup.
- Disable NATS. We don’t need it for this example and it would otherwise throw an error because we haven’t configured it yet.
- Log a message to the console when the service starts.
Running the Service¶
To run the service, run the following command:
Success
You should see the following output:
Running in development mode
When you run the service with the --dev
flag, the service will use default values for missing environment variables. You’ll learn more about this in the configuration section.
Next Steps¶
Now that you have a basic service running, you should have a look at how to make your service configurable.
If you prefer to learn by example, you can also have a look at the samples.