Security News
The Risks of Misguided Research in Supply Chain Security
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
gatsby-cli
Advanced tools
Gatsby command-line interface for creating new sites and running Gatsby commands
The gatsby-cli npm package is a command-line interface tool for creating, developing, and managing Gatsby sites. It provides a range of commands to streamline the development process, from setting up new projects to deploying them.
Create a new Gatsby site
This command initializes a new Gatsby site in a directory called 'my-gatsby-site'. It sets up the necessary files and dependencies to get started with a Gatsby project.
gatsby new my-gatsby-site
Develop a Gatsby site
This command starts a local development server and watches for changes in your Gatsby site. It provides hot-reloading and a GraphQL data layer for building and testing your site locally.
gatsby develop
Build a Gatsby site
This command generates a production-ready static site. It compiles your site into static files that can be deployed to any web server.
gatsby build
Serve a Gatsby site
This command starts a local server to serve the production build of your site. It is useful for testing the final output before deploying it.
gatsby serve
Clean Gatsby cache
This command deletes the .cache and public directories. It is useful for troubleshooting and ensuring a clean build environment.
gatsby clean
Create React App is a command-line tool to set up a new React project with a single command. It provides a similar experience to gatsby-cli but is focused on React applications rather than static site generation.
Next.js is a React framework that provides a CLI for creating and managing projects. It offers server-side rendering and static site generation, making it a versatile alternative to Gatsby for building modern web applications.
Vue CLI is a command-line tool for scaffolding Vue.js projects. It offers a similar set of features to gatsby-cli but is tailored for Vue.js applications, including project creation, development server, and build commands.
The Gatsby command line interface (CLI) is the main tool you use to initialize, build and develop Gatsby sites.
To use the Gatsby CLI you must either:
npm install -g gatsby-cli
, where you execute commands with the syntax gatsby new
, ornpx
, where you execute commands with the syntax npx gatsby new
Useful Gatsby CLI commands are also pre-defined in starters as run scripts.
All the following documentation is available in the tool by running gatsby --help
.
Available commands are:
new
Runs an interactive shell with a prompt that helps you set up a CMS, styling system and plugins if you wish.
To create a new site with the prompt, execute:
gatsby new
You can also skip the prompt and clone a starter directly from GitHub. For example, to clone a new gatsby-starter-blog, execute:
gatsby new my-new-blog https://github.com/gatsbyjs/gatsby-starter-blog
The first argument (e.g. my-new-blog
) is the name of your site, and the second argument is the GitHub URL of the starter you want to clone.
Note: The site name should only consist of letters and numbers. If you specify a
.
,./
or a<space>
in the name,gatsby new
will throw an error.
develop
Compiles and serves a development build of your site that reflects your source code changes in the browser in real time. Should be run from the root of your project.
gatsby develop
Options include:
Option | Description |
---|---|
-H , --host | Set host. Defaults to localhost |
-p , --port | Set port. Defaults to env.PORT or 8000 |
-o , --open | Open the site in your (default) browser for you |
-S , --https | Use HTTPS |
--inspect | Opens a port for debugging |
To set up HTTPS, follow the Local HTTPS guide.
To include a URL you can access from other devices on the same network, execute:
gatsby develop -H 0.0.0.0
You will see this output:
You can now view gatsbyjs.com in the browser.
⠀
Local: http://0.0.0.0:8000/
On Your Network: http://192.168.0.212:8000/ // highlight-line
You can use the "On Your Network" URL to access your site within your network.
build
Compiles your site for production so it can be deployed. Should be run from the root of your project.
gatsby build
Options include:
Option | Description |
---|---|
--prefix-paths | Build site with link paths prefixed (set pathPrefix in your config) |
--no-uglify | Build site without uglifying JS bundles (for debugging) |
--profile | Build site with react profiling. See Profiling Site Performance with React Profiler |
--open-tracing-config-file | Tracer configuration file (OpenTracing compatible). See Performance Tracing |
--graphql-tracing | Trace (see above) every graphql resolver, may have performance implications. |
--no-color , --no-colors | Disables colored terminal output |
In addition to these build options, there are some optional build environment variables for more advanced configurations that can adjust how a build runs. For example, setting CI=true
as an environment variable will tailor output for dumb terminals.
serve
Serves the production build of your site for testing prior to deployment. Should be run from the root of your project.
gatsby serve
Options include:
Option | Description |
---|---|
-H , --host | Set host. Defaults to localhost |
-p , --port | Set port. Defaults to 9000 |
-o , --open | Open the site in your default browser for you |
--prefix-paths | Serve site with link paths prefixed (if built with pathPrefix in your gatsby-config file). |
info
Show helpful environment information which is required in bug reports. Should be run from the root of your project.
gatsby info
Options include:
Option | Description |
---|---|
-C , --clipboard | Copy environment information to your clipboard |
clean
Delete the .cache
and public
directories. Should be run from the root of your project.
gatsby clean
This is useful as a last resort when your local project seems to have issues or content does not seem to be refreshing. Issues this may fix commonly include:
repl
Open a Node.js REPL (interactive shell) with context of your Gatsby environment. Should be run from the root of your project.
gatsby repl
Gatsby will prompt you to type in commands and explore. When it shows this: gatsby >
, you can type in one of these commands to see their values in real time:
babelrc
components
dataPaths
getNodes()
nodes
pages
schema
siteConfig
staticQueries
To exit the REPL:
Ctrl+C
or Ctrl+D
twice, or.exit
and press Enter
When combined with the GraphQL explorer, these REPL commands could be very helpful for understanding your Gatsby site's data.
FAQs
Gatsby command-line interface for creating new sites and running Gatsby commands
The npm package gatsby-cli receives a total of 233,858 weekly downloads. As such, gatsby-cli popularity was classified as popular.
We found that gatsby-cli demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 12 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.