Serverpod in Flutter

Introduction
As a Flutter developer, choosing the right backend solution is crucial for building scalable, secure, and high-performance applications. Traditional backend options like Firebase, Node.js, and Django work well, but they often require switching between multiple languages, frameworks, and dependencies.
This is where Serverpod comes in — a Dart-based backend framework specifically designed for Flutter applications. With automatic API generation, PostgreSQL integration, authentication, WebSockets, and caching, Serverpod makes backend development seamless and efficient while allowing developers to stay within the Flutter ecosystem.
This blog will cover everything you need to know about integrating Serverpod with Flutter, from setup to advanced features like database handling, authentication, and real-time updates.
If you’re looking for the best Flutter app development company for your mobile application then feel free to contact us at — support@flutterdevs.com.
Table of Contents:
Why Choose Serverpod for Your Flutter Backend?
Setting Up Serverpod in Flutter
Creating API Endpoints in Serverpod
Working with the Database in Serverpod
Authentication & User Management in Serverpod
WebSockets & Real-time Features
Deployment & Scaling Serverpod
1. Why Choose Serverpod for Your Flutter Backend?
As a Flutter developer, using Serverpod has several advantages over other backend solutions:
1. Dart-Powered Backend
- No need to switch between multiple languages like Node.js or Python.
- Full control over backend logic while staying within the Flutter ecosystem.
2. Seamless API Integration
- Serverpod automatically generates type-safe API endpoints, reducing manual work.
- Easy-to-use client SDK for Flutter apps.
3. Built-in Authentication & Security
- OAuth, JWT, and role-based access control (RBAC) out of the box.
- Secure API endpoints with authentication middleware.
4. Database & ORM Support
- Uses PostgreSQL as the database with an intuitive ORM.
- Supports relations, migrations, and query building using Dart.
5. WebSocket & Real-time Features
- Built-in WebSocket support for real-time apps like chat, notifications, and live updates.
6. Performance & Scalability
- Serverpod is optimized for speed and supports Redis caching to improve performance.
- Can be deployed on Docker, AWS, Google Cloud, or DigitalOcean for production scaling.
2. Setting Up Serverpod in Flutter
1. Install Serverpod CLI
First, install the Serverpod CLI tool globally:
dart pub global activate serverpod_cli
Verify the installation:
serverpod --version
2. Create a Serverpod Project
Run the following command to generate a new Serverpod project:
serverpod create my_serverpod_project
This will create three directories:
my_serverpod_project_server
→ Backend servermy_serverpod_project_client
→ Generated Flutter client SDKmy_serverpod_project_flutter
→ A sample Flutter app (optional)
3. Set Up PostgreSQL
Serverpod requires PostgreSQL as the database. Install it based on your OS:
- Linux:
sudo apt install postgresql
- MacOS:
brew install postgresql
- Windows: Install via PostgreSQL official site
Create a new database:
psql -U postgres
CREATE DATABASE my_serverpod_db;
Then, configure my_serverpod_project_server/config/development.yaml
:
database:
host: localhost
port: 5432
name: my_serverpod_db
user: postgres
password: yourpassword
4. Start the Server
Navigate to the server
folder and run:
cd my_serverpod_project_server
serverpod run
Expected output:
Server listening on port 8080
5. Integrate Serverpod with Flutter
In your Flutter project, add the generated client SDK:
dependencies:
my_serverpod_project_client:
path: ../my_serverpod_project_client
Then, initialize the Serverpod client in Flutter:
import 'package:my_serverpod_project_client/my_serverpod_project_client.dart';
final client = Client('http://localhost:8080/')
..connectivityMonitor = ServerpodClientShared().connectivityMonitor;
3. Creating API Endpoints in Serverpod
1. Define an API Endpoint
Edit my_serverpod_project_server/lib/src/endpoints/example.dart
:
import 'package:serverpod/serverpod.dart';
class ExampleEndpoint extends Endpoint {
Future<String> sayHello(Session session, String name) async {
return 'Hello, $name! Welcome to Serverpod!';
}
}
Run:
serverpod generate
2. Call the API from Flutter
Use the generated client in Flutter to call the API:
void fetchGreeting() async {
final message = await client.example.sayHello('Flutter Dev');
print(message); // Outputs: Hello, Flutter Dev! Welcome to Serverpod!
}
4. Working with the Database in Serverpod
- Define a Database Model Edit
my_serverpod_project_server/protocol/user.yaml
:
class: User
table: users
fields:
name: String
email: String
Generate the database migration and apply it
serverpod generate
serverpod migrate
2. Insert and Retrieve Data
Modify example.dart
:
import 'package:serverpod/serverpod.dart';
import '../generated/protocol.dart';
class ExampleEndpoint extends Endpoint {
Future<void> createUser(Session session, String name, String email) async {
final user = User(name: name, email: email);
await User.insert(session, user);
}
Future<List<User>> getUsers(Session session) async {
return await User.find(session);
}
}
3. Fetch Data in Flutter
Use the Flutter client to retrieve users:
void getUsers() async {
final users = await client.example.getUsers();
for (var user in users) {
print('${user.name} - ${user.email}');
}
}
5. Authentication & User Management in Serverpod
1. Enable Authentication
In server
config, enable authentication:
authentication:
enabled: true
providers:
- type: password
2. Register a User
Modify auth.dart
in server
:
class AuthEndpoint extends Endpoint {
Future<bool> register(Session session, String email, String password) async
{
return await Users.createUser(session, email, password);
}
Future<User?> login(Session session, String email, String password) async {
return await Users.signIn(session, email, password);
}
}
3. Call Authentication API in Flutter
Use the client SDK in Flutter:
void registerUser() async {
bool success = await client.auth.register('user@example.com', 'password123');
print(success ? 'Registered successfully' : 'Registration failed');
}
6. WebSockets & Real-time Features
1. Enable WebSockets
Modify server
settings:
websockets:
enabled: true
2. Create a WebSocket Listener
In server
:
class ChatEndpoint extends Endpoint {
void sendMessage(Session session, String message) {
session.messages.postMessage('chat', message);
}
}
3. Listen to WebSocket Messages in Flutter
In Flutter, listen for updates:
client.chat.stream.listen((message) {
print('New message: $message');
});
7. Deployment & Scaling Serverpod
Deploying on Docker
Generate a Docker image:
serverpod generate
serverpod docker build
serverpod docker run
Supports AWS, Google Cloud, and DigitalOcean for production.
8. Challenges in Using Serverpod
Limited Ecosystem
- Since Serverpod is relatively new, it lacks third-party plugins and integrations compared to Firebase or Node.js.
Hosting & DevOps Complexity
- Unlike Firebase, Serverpod requires a VPS or cloud setup (AWS, Google Cloud, or DigitalOcean).
Learning Curve
- While it’s Dart-based, understanding ORM, database migrations, and WebSockets may take time for new developers.
9. Limitations of Serverpod
Lack of NoSQL Support
- Serverpod only supports PostgreSQL, meaning MongoDB or Firestore users need an alternative approach.
Limited Documentation & Community
- Serverpod doesn’t have as large a community as Firebase or Node.js, leading to fewer tutorials and StackOverflow answers.
Not Ideal for Low-Code Development
- Serverpod is developer-focused and not a low-code backend like Firebase, meaning you need backend coding experience.
10. Future Scope of Serverpod
More Database Support
- Future versions may add support for MySQL and NoSQL databases.
Improved DevOps & Hosting
- A one-click deployment solution (like Firebase Hosting) could make it easier to use.
More Third-Party Integrations
- Adding payment gateways, analytics tools, and cloud storage support will improve its adoption.
Better Mobile & Web Support
- Improved WebSockets and GraphQL support will enhance real-time applications.
11. Conclusion
Serverpod is a powerful Dart-based backend framework that simplifies backend development for Flutter apps. With features like automatic API generation, database integration, authentication, caching, and WebSockets, it’s an excellent alternative to traditional backend solutions.
If you’re looking for a Flutter-first backend that’s scalable and easy to manage, Serverpod is worth exploring.
❤ ❤ Thanks for reading this article ❤❤
If I got something wrong? Let me know in the comments. I would love to improve.
Clap 👏 If this article helps you.
12. Reference
Get started | Serverpod
This page will help you understand how a Serverpod project is structured, how to make calls to endpoints, and how to…docs.serverpod.dev
serverpod | Dart package
Serverpod is an open-source, scalable app server, written in Dart for the Flutter community.pub.dev
Feel free to connect with us:
And read more articles from FlutterDevs.com.
FlutterDevs team of Flutter developers to build high-quality and functionally-rich apps. Hire a Flutter developer for your cross-platform Flutter mobile app project hourly or full-time as per your requirement! For any flutter-related queries, you can connect with us on Facebook, GitHub, Twitter, and LinkedIn.
We welcome feedback and hope that you share what you’re working on using #FlutterDevs. We truly enjoy seeing how you use Flutter to build beautiful, interactive web experiences.
