Photon ist der Kernindexer für ZK-Komprimierung auf der Solana-Blockchain. Es bietet schnelle Indizierungsfunktionen, Snapshot-Unterstützung und flexible Datenbankoptionen für lokale und Produktionsbereitstellungen.
sudo apt install -y build-essential pkg-config libssl-dev
photon-indexer
installieren: cargo install photon-indexer
photon
photon --rpc-url=https://api.devnet.solana.com
photon --rpc-url=https://api.devnet.solana.com --grpc-url= < grpc_url >
photon --db-url=postgres://postgres@localhost/postgres
photon --start-slot=123
photon --help
Photon unterstützt Snapshots für schnelles Bootstrapping.
photon-snapshot-loader --snapshot-dir= ~ /snapshot --snapshot-server-url=https://photon-devnet-snapshot.helius-rpc.com
photon --snapshot-dir= ~ /snapshot --rpc-url=https://api.devnet.solana.com --db-url=postgres://postgres@localhost/postgres
Erstellen Sie einen lokalen Snapshot:
photon-snapshotter --snapshot-dir= ~ /snapshot
Speichern Sie Snapshots in einem R2-Bucket:
photon-snapshotter --r2-bucket=some-bucket --r2-prefix=prefix
Hinweis: Legen Sie die Umgebungsvariablen R2_ACCESS_KEY
, R2_ACCOUNT_ID
und R2_SECRET_KEY
fest, wenn Sie R2 verwenden.
Photon unterstützt sowohl Postgres als auch SQLite. Standardmäßig wird eine In-Memory-SQLite-Datenbank verwendet.
So verwenden Sie eine benutzerdefinierte Datenbank:
export DATABASE_URL= " postgres://postgres@localhost/postgres "
photon-migration up
photon --db-url= $DATABASE_URL
export MAINNET_RPC_URL=https://api.mainnet-beta.solana.com
export DEVNET_RPC_URL=https://api.devnet.solana.com
export TEST_DATABASE_URL= " postgres://postgres@localhost/postgres "
npm install -g @apidevtools/swagger-cli
wget https://dl.min.io/server/minio/release/linux-amd64/minio
chmod +x minio
docker run -p 3001:3001 docker.io/pmantica1/light-prover:1
cargo test
Hinweis: Alle Migrationen werden während der Tests sowohl für Postgres als auch für SQLite automatisch ausgeführt.
cargo install sea-orm-cli --version 0.10.6
sea-orm-cli generate entity -o src/dao/generated
Generieren Sie OpenAPI-Schemas:
cargo run --bin=photon-openapi
Für Unterstützung oder Fragen öffnen Sie bitte ein Problem auf Github oder wenden Sie sich an den Helius-Discord.