S3-Compatible Storage Setup
Overview
S3-compatible storage is used for:
- Platform assets storage
- Blockchain data persistence
- File management
- State storage
Deployment Options
- Managed Service (Recommended)
- Self-Hosted MinIO
AWS S3 (Native)
- Create new S3 bucket:
- Choose region
- Enable versioning
- Configure default encryption
- Create IAM user:
- Generate access key and secret
- Attach minimal required permissions
Digital Ocean Spaces
- Access Digital Ocean Console
- Create new Spaces bucket:
- Choose datacenter region
- Configure CDN (optional)
- Create Spaces access key
tip
Managed services provide:
- Built-in redundancy
- Automatic scaling
- Global availability
- Integrated monitoring
MinIO Installation
- Install MinIO:
helm upgrade --install minio oci://registry-1.docker.io/bitnamicharts/minio \
--namespace minio \
--version 13.8.4 \
--create-namespace \
--set defaultBuckets=platform-bucket \
--set auth.rootUser=admin \
--set auth.rootPassword=your-secure-password \
--set provisioning.enabled=true \
--set "provisioning.config[0].name=region" \
--set "provisioning.config[0].options.name=us-east-1"
- Create service account:
# Generate access credentials
mc admin user svcacct add minio platform-user
caution
For production use:
- Configure proper storage class
- Set up backup procedures
- Enable encryption
- Configure monitoring
State Encryption
Generate an encryption key for state data:
openssl rand -base64 32
Important
Store this encryption key securely - it's used to protect platform state data.
Information Collection
Required Values for Platform Installation
- S3 endpoint URL
- Bucket name
- Access key ID
- Secret access key
- Region
- State encryption key
Example Configuration
deploymentEngine:
state:
s3ConnectionUrl: 's3://bucket-name?region=us-east-1&endpoint=your-endpoint'
credentials:
encryptionKey: 'your-generated-key' # From openssl command
aws:
accessKeyId: 'your-access-key'
secretAccessKey: 'your-secret-key'
region: 'us-east-1'
Validation
Test your S3 configuration:
# Using AWS CLI
aws s3 ls s3://your-bucket \
--endpoint-url your-endpoint \
--access-key your-access-key \
--secret-key your-secret-key
# Expected: List of objects or empty result
Troubleshooting
Common issues and solutions:
-
Access Denied
- Verify credentials
- Check bucket permissions
- Confirm IAM/policy settings
- Validate endpoint URL format
-
Connection Issues
- Check endpoint accessibility
- Verify region setting
- Confirm network access
- Check SSL/TLS requirements
Next Steps
- ✅ Set up S3-compatible storage
- ✅ Generate encryption key
- ➡️ Proceed to HashiCorp Vault Setup
Need Help?
Contact [email protected] if you encounter any issues.