Deployment
Learn how to deploy your Metronic Next.js application to various hosting platforms.
Deployment
This guide covers deploying your Metronic Next.js application to production environments.
Building for Production
# Navigate to your project directory
cd your-nextjs-project
 
# Install dependencies (if needed)
npm install
 
# Build for production
npm run buildThis creates a .next directory with optimized files ready for deployment.
Configuration
Environment Variables
For production, create a .env.production file:
NEXT_PUBLIC_APP_NAME=metronic-nextjs
NEXT_PUBLIC_API_URL=https://your-production-api.com/api
NEXTAUTH_URL=https://your-domain.com
NEXTAUTH_SECRET=your-secret-key
Remember that only variables prefixed with NEXT_PUBLIC_ will be exposed to the browser.
Deployment Options
Vercel (Recommended)
Vercel provides the simplest deployment experience for Next.js applications:
- Push your code to a Git repository (GitHub, GitLab, BitBucket)
- Import your repository on vercel.com
- Vercel will automatically detect Next.js and use the optimal build settings
Alternatively, use the Vercel CLI:
# Install Vercel CLI
npm install -g vercel
 
# Deploy
vercelNext.js-Specific Deployment Options
Self-Hosted Static Export
For static site hosting (without server-side features):
- Add this to your next.config.mjs:
export default {
  output: 'export',
}- Build your application:
npm run buildThis generates a static out directory you can deploy to any static hosting service.
Node.js Server
For server-side rendering with a Node.js server:
- Build your application:
npm run build- Start the Node.js server:
npm run startThis starts a production server on port 3000 by default.
Common Issues
Image Optimization
When using Next.js Image Optimization with static export, configure the loader in next.config.mjs:
export default {
  images: {
    loader: 'custom',
    loaderFile: './my-image-loader.js',
  }
}Create a custom loader file:
// my-image-loader.js
export default function myImageLoader({ src, width, quality }) {
  return `https://your-cdn.com/${src}?w=${width}&q=${quality || 75}`
}API Routes
API routes don't work with static exports. You'll need a server-side deployment method or serverless functions if you're using API routes.
Server Components
Server components require a server-side deployment method, such as Vercel, Node.js server, or Docker. They won't work with static exports.
Testing Production Build Locally
To preview your production build before deployment:
npm run build
npm run startVisit http://localhost:3000 to preview your production build.
Continuous Deployment
For automated deployments, configure CI/CD pipelines:
GitHub Actions Example
Create a .github/workflows/deploy.yml file:
name: Deploy Next.js site to Vercel
 
on:
  push:
    branches: ["main"]
 
jobs:
  deploy:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v3
      - uses: actions/setup-node@v3
        with:
          node-version: 18
      - name: Install Vercel CLI
        run: npm install --global vercel@latest
      - name: Deploy to Vercel
        run: vercel deploy --prod --token=${{ secrets.VERCEL_TOKEN }}For more information on Next.js deployment, refer to the official documentation.