Deploy a dynamic blog using Cloudflare Pages, D1, R2, and AI

Published on
·
2 min read
0
Deploy a dynamic blog using Cloudflare Pages, D1, R2, and AI.

Deploy your own

To deploy PenX to cloudflare, follow these steps:

1. Clone the PenX Repository

First, clone the PenX project to your local machine by executing the following command:
git clone https://github.com/penx-labs/penx

2. Configure wrangler.toml

Next, rename wrangler.toml.example to wrangler.toml.

3. Create a Cloudflare D1 Database

Run the following command to create a Cloudflare D1 database:
npx wrangler d1 create penx-blog
If successful, you will see a confirmation message similar to this:
✅ Successfully created DB 'penx-blog' in region WNAM
Created your new D1 database.

[[d1_databases]]
binding = "DB"
database_name = "penx-blog"
database_id = "00e31c14-e6ae-4612-9bc3-d25c6a1f8023d"
Copy the database_id and update it in your wrangler.toml file.

4. Create Cloudflare R2 Bucket

Before create R2 Bucket, you need to bind a credit card to Cloudflare.
Create a Cloudflare R2 bucket by running:
npx wrangler r2 bucket create penx-bucket
You should receive a message confirming the creation of the bucket:
✅ Created bucket 'penx-bucket' with default storage class of Standard.

Configure your Worker to write objects to this bucket:

[[r2_buckets]]
bucket_name = "penx-bucket"
binding = "penx_bucket"

5. Configure Session Password

To set up a session password, visit this link to generate a secure password. Replace SESSION_PASSWORD in your wrangler.toml with this value.

6. Deploy to Cloudflare Pages

Finally, deploy your blog by running these commands:
pnpm install
pnpm run db:generate # Required for initial release
pnpm run db:migrate:prod # Required for initial release
pnpm run deploy
Upon successful deployment, you will receive a URL like: https://penx-cloudflare.pages.dev.

Examples Blogs

  • https://my-penx-blog.pages.dev
  • https://demo1.penx.io
  • https://demo2.penx.io
  • https://demo3.penx.io
  • https://demo4.penx.io
IPFS CID:QmYEipAqMmjP8ugSfNQ4gyQnZi2TNkuH8wMFxHnkyiEstp