You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
8.2 KiB
8.2 KiB
SeaweedFS PostgreSQL Protocol Examples
This directory contains examples demonstrating how to connect to SeaweedFS using the PostgreSQL wire protocol.
Starting the PostgreSQL Server
# Start with trust authentication (no password required)
weed postgres -port=5432 -master=localhost:9333
# Start with password authentication
weed postgres -port=5432 -auth=password -users="admin:secret;readonly:view123"
# Start with MD5 authentication (more secure)
weed postgres -port=5432 -auth=md5 -users="user1:pass1;user2:pass2"
# Start with TLS encryption
weed postgres -port=5432 -tls-cert=server.crt -tls-key=server.key
# Allow connections from any host
weed postgres -host=0.0.0.0 -port=5432
Client Connections
psql Command Line
# Basic connection (trust auth)
psql -h localhost -p 5432 -U seaweedfs -d default
# With password
PGPASSWORD=secret psql -h localhost -p 5432 -U admin -d default
# Connection string format
psql "postgresql://admin:secret@localhost:5432/default"
# Connection string with parameters
psql "host=localhost port=5432 dbname=default user=admin password=secret"
Programming Languages
Python (psycopg2)
import psycopg2
# Connect to SeaweedFS
conn = psycopg2.connect(
host="localhost",
port=5432,
user="seaweedfs",
database="default"
)
# Execute queries
cursor = conn.cursor()
cursor.execute("SELECT * FROM my_topic LIMIT 10")
for row in cursor.fetchall():
print(row)
cursor.close()
conn.close()
Java JDBC
import java.sql.*;
public class SeaweedFSExample {
public static void main(String[] args) throws SQLException {
String url = "jdbc:postgresql://localhost:5432/default";
Connection conn = DriverManager.getConnection(url, "seaweedfs", "");
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM my_topic LIMIT 10");
while (rs.next()) {
System.out.println("ID: " + rs.getLong("id"));
System.out.println("Message: " + rs.getString("message"));
}
rs.close();
stmt.close();
conn.close();
}
}
Go (lib/pq)
package main
import (
"database/sql"
"fmt"
_ "github.com/lib/pq"
)
func main() {
db, err := sql.Open("postgres",
"host=localhost port=5432 user=seaweedfs dbname=default sslmode=disable")
if err != nil {
panic(err)
}
defer db.Close()
rows, err := db.Query("SELECT * FROM my_topic LIMIT 10")
if err != nil {
panic(err)
}
defer rows.Close()
for rows.Next() {
var id int64
var message string
err := rows.Scan(&id, &message)
if err != nil {
panic(err)
}
fmt.Printf("ID: %d, Message: %s\n", id, message)
}
}
Node.js (pg)
const { Client } = require('pg');
const client = new Client({
host: 'localhost',
port: 5432,
user: 'seaweedfs',
database: 'default',
});
async function query() {
await client.connect();
const result = await client.query('SELECT * FROM my_topic LIMIT 10');
console.log(result.rows);
await client.end();
}
query().catch(console.error);
SQL Operations
Basic Queries
-- List databases
SHOW DATABASES;
-- List tables (topics)
SHOW TABLES;
-- Describe table structure
DESCRIBE my_topic;
-- or use the shorthand: DESC my_topic;
-- Basic select
SELECT * FROM my_topic;
-- With WHERE clause
SELECT id, message FROM my_topic WHERE id > 1000;
-- With LIMIT
SELECT * FROM my_topic LIMIT 100;
Aggregations
-- Count records
SELECT COUNT(*) FROM my_topic;
-- Multiple aggregations
SELECT
COUNT(*) as total_messages,
MIN(id) as min_id,
MAX(id) as max_id,
AVG(amount) as avg_amount
FROM my_topic;
-- Aggregations with WHERE
SELECT COUNT(*) FROM my_topic WHERE status = 'active';
System Columns
-- Access system columns
SELECT
id,
message,
_timestamp_ns as timestamp,
_key as partition_key,
_source as data_source
FROM my_topic;
-- Filter by timestamp
SELECT * FROM my_topic
WHERE _timestamp_ns > 1640995200000000000
LIMIT 10;
PostgreSQL System Queries
-- Version information
SELECT version();
-- Current database
SELECT current_database();
-- Current user
SELECT current_user;
-- Server settings
SELECT current_setting('server_version');
SELECT current_setting('server_encoding');
psql Meta-Commands
-- List tables
\d
\dt
-- List databases
\l
-- Describe specific table
\d my_topic
\dt my_topic
-- List schemas
\dn
-- Help
\h
\?
-- Quit
\q
Database Tools Integration
DBeaver
- Create New Connection → PostgreSQL
- Settings:
- Host: localhost
- Port: 5432
- Database: default
- Username: seaweedfs (or configured user)
- Password: (if using password auth)
pgAdmin
- Add New Server
- Connection tab:
- Host: localhost
- Port: 5432
- Username: seaweedfs
- Database: default
DataGrip
- New Data Source → PostgreSQL
- Configure:
- Host: localhost
- Port: 5432
- User: seaweedfs
- Database: default
Grafana
- Add Data Source → PostgreSQL
- Configuration:
- Host: localhost:5432
- Database: default
- User: seaweedfs
- SSL Mode: disable
BI Tools
Tableau
- Connect to Data → PostgreSQL
- Server: localhost
- Port: 5432
- Database: default
- Username: seaweedfs
Power BI
- Get Data → Database → PostgreSQL
- Server: localhost
- Database: default
- Username: seaweedfs
Connection Pooling
Java (HikariCP)
HikariConfig config = new HikariConfig();
config.setJdbcUrl("jdbc:postgresql://localhost:5432/default");
config.setUsername("seaweedfs");
config.setMaximumPoolSize(10);
HikariDataSource dataSource = new HikariDataSource(config);
Python (connection pooling)
from psycopg2 import pool
connection_pool = psycopg2.pool.SimpleConnectionPool(
1, 20,
host="localhost",
port=5432,
user="seaweedfs",
database="default"
)
conn = connection_pool.getconn()
# Use connection
connection_pool.putconn(conn)
Security Best Practices
Use TLS Encryption
# Generate self-signed certificate for testing
openssl req -x509 -newkey rsa:4096 -keyout server.key -out server.crt -days 365 -nodes
# Start with TLS
weed postgres -tls-cert=server.crt -tls-key=server.key
Use MD5 Authentication
# More secure than password auth
weed postgres -auth=md5 -users="admin:secret123;readonly:view456"
Limit Connections
# Limit concurrent connections
weed postgres -max-connections=50 -idle-timeout=30m
Troubleshooting
Connection Issues
# Test connectivity
telnet localhost 5432
# Check if server is running
ps aux | grep "weed postgres"
# Check logs for errors
tail -f /var/log/seaweedfs/postgres.log
Common Errors
"Connection refused"
- Ensure PostgreSQL server is running
- Check host/port configuration
- Verify firewall settings
"Authentication failed"
- Check username/password
- Verify auth method configuration
- Ensure user is configured in server
"Database does not exist"
- Use correct database name (default: 'default')
- Check available databases:
SHOW DATABASES
"Permission denied"
- Check user permissions
- Verify authentication method
- Use correct credentials
Performance Tips
- Use LIMIT clauses for large result sets
- Filter with WHERE clauses to reduce data transfer
- Use connection pooling for multi-threaded applications
- Close resources properly (connections, statements, result sets)
- Use prepared statements for repeated queries
Monitoring
Connection Statistics
-- Current connections (if supported)
SELECT COUNT(*) FROM pg_stat_activity;
-- Server version
SELECT version();
-- Current settings
SELECT name, setting FROM pg_settings WHERE name LIKE '%connection%';
Query Performance
-- Use EXPLAIN for query plans (if supported)
EXPLAIN SELECT * FROM my_topic WHERE id > 1000;
This PostgreSQL protocol support makes SeaweedFS accessible to the entire PostgreSQL ecosystem, enabling seamless integration with existing tools, applications, and workflows.