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.
|
10 hours ago | |
---|---|---|
.. | ||
README.md | 12 hours ago | |
test_client.py | 1 day ago |
README.md
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 ORDER BY _timestamp_ns DESC 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.