Fess is very powerful and easily deployable Enterprise Search Server.
Find a file
2021-05-20 01:05:42 +00:00
.github replace with maven build 2020-10-02 07:07:41 +09:00
.travis update travis script 2019-02-07 05:45:06 +09:00
dbflute_fess fix #1916 remove ...ToRole and ...ToLabel 2018-11-28 21:59:14 +09:00
src fix #2567 remove expand_ngram 2021-05-10 21:36:49 +09:00
.gitattributes modify git configuration. 2013-09-15 21:38:11 +09:00
.gitignore code cleanup 2021-05-04 06:46:09 +09:00
.travis.yml use xenial 2019-04-29 09:54:21 +09:00
dbflute.xml es-7.12 2021-03-27 11:59:52 +09:00
deps.xml update dependencies 2021-04-24 11:36:13 +09:00
LICENSE update LICENSE NOTICE 2018-05-09 06:35:34 +09:00
MIGRATION.md Update MIGRATION.md 2019-03-05 01:12:02 -05:00
NOTICE fix #2366 use https 2020-01-16 08:53:08 +09:00
plugin.xml fix #2519 remove dataformat plugin, and rename getFessEsClient method 2021-01-24 21:49:30 +09:00
pom.xml [maven-release-plugin] prepare release fess-13.12.2 2021-05-20 01:05:42 +00:00
README.md Update README.md 2021-04-29 09:50:09 +09:00

Fess Enterprise Search Server Tweet

Build Status Maven Central License

Overview

Fess is a very powerful and easily deployable Enterprise Search Server. You can quickly install and run Fess on any platform where you can run the Java Runtime Environment. Fess is provided under the Apache License 2.0.

Fess is based on Elasticsearch, but knowledge/experience about Elasticsearch is not required. Fess provides an easy to use Administration GUI to configure the system via your browser. Fess also contains a Crawler, which can crawl documents on a web server, file system, or Data Store (such as a CSV or database). Many file formats are supported including (but not limited to): Microsoft Office, PDF, and zip.

Fess Site Search is a free alternative to Google Site Search. For more details, see the FSS JS Generator documentation.

Website

fess.codelibs.org

Issues/Questions

discuss.codelibs.org

Getting Started

There are 2 ways to try Fess. The first is to download and install yourself. The second is to use Docker.

Download and Install/Run

Fess 13.12 is now available and can be downloaded on the Releases page. Downloads come in 3 flavors: deb, rpm, zip.

The following commands show how to use the zip download:

$ unzip fess-13.12.x.zip
$ cd fess-13.12.x
$ ./bin/fess

For more details, see the Installation Guide.

Docker

We provide Docker images on ghcr.io. We also provide a Docker Compose (YAML) file in this repository.

Browser UI

Search UI

Admin UI

You can register crawling targets in the Admin UI on the (Web, File, Data Store) crawler configuration pages, and then start the Crawler manually on the Scheduler page.

Migration from another search provider

Please see MIGRATION.md.

Data Store

Currently, Fess supports crawling the following storage locations and APIs:

Theme

Ingest

Script

Localization

Japanese

Korean

Development Information

Get Source Code

  1. Clone Fess's repository:

    $ cd ~/workspace
    $ git clone https://github.com/codelibs/fess.git
    
  2. Import the cloned repository as a Maven project on Eclipse or another IDE.

Setup for Elasticsearch Plugins

Run antrun:run to download plugins into the plugins directory:

$ mvn antrun:run

Run Fess

Run or debug org.codelibs.fess.FessBoot on your IDE, and then access http://localhost:8080/

Build Package

Run the package goal and then the release file will be created in target/releases.

$ mvn package
$ mvn rpm:rpm   # .rpm package
$ mvn jdeb:jdeb # .deb package

Generate Source Code

$ mvn dbflute:download # (one time command)
$ mvn dbflute:freegen
$ mvn license:format

Integration Tests

Launch Fess Server and run the following command:

$ mvn test -P integrationTests -Dtest.fess.url="http://localhost:8080" -Dtest.es.url="http://localhost:9201"

To run a single test case, you can use:

$ mvn test -P integrationTests -Dtest.fess.url="http://localhost:8080" -Dtest.es.url="http://localhost:9201" -Dtest=SearchApiTests

Translate In Your Language

Fess is internationalized software.

If you want to add labels/messages for your language, please translate properties file and then rename to fess_*_[lang].properties.

For search/index analyzer, if doc.json contains lang_[lang] for your language, please modify the analyzer for your language. For more details about Analyzers, see the Elasticsearch documentation.

We welcome pull requests for your language.

Powered By