Skip to content

Latest commit

 

History

History
210 lines (160 loc) · 8.11 KB

README.md

File metadata and controls

210 lines (160 loc) · 8.11 KB

Image Search Workshop

Summary

  1. Introduction
  2. Prerequisite
  3. Usage
  4. Run as a linux daemon
  5. Tips
  6. Online demo page
  7. Thanks
  8. Support

Introduction

This is a demo workshop that showcases Image Search, an Alibaba Cloud image search service. After its completion, you will be able to upload images and try to search them by uploading a similar picture.

This demo is a website compatible with desktop computers and smartphones. It contains two main pages:

  • Manage objects

    This page allows users to add/update/delete product images in the database.

  • Home

    This page lets users to search for products that look similar to an uploaded photo (this photo can come from a JPEG file or directly from a camera when the user views this page on a smartphone).

The following diagram represents the demo architecture:

image_search_demo_architecture.svg

There are two databases: one for storing names & images of registered objects, and one managed by the Image Search instance (it only stores selected image features required for searches). Both databases are synchronized via object UUIDs.

Prerequisite

Product Search instance

Before running the application, you first need to create a Product Search instance that will allow you to use the image search API:

  1. Create an Alibaba cloud account

    If you don't have an account, please follow this document to create one.

  2. Create a Product Search instance

    You need an Product Search instance. You can create it from the Product Search console. For more information, please read this document.

  3. Create an access key

    You need an accessKeyId and an accessKeySecret to access your Product Search instance. Please follow this document to obtain an access key id and secret.

  4. If you want to run this demo in Alibaba Cloud, you can also create an ECS instance.

Local environment requirements

This application requires the following environment:

  • GNU Linux (CentOS 7.4+ is recommended), MAC OSX or Windows
  • A Java development environment:

You can check your environment with the following commands in a terminal:

# Check that Java JDK is installed
javac -version

# Check that Maven is installed
mvn -v

You can check what Java version you have and change it with the following commands:

# If you use CentOS
sudo alternatives --config java

# If you use Mac OSX
/usr/libexec/java_home -V
export JAVA_HOME=`/usr/libexec/java_home -v 1.8`

Usage

  1. Build the demo

    Run the following commands.

    # Change directory if needed
    cd /path/to/your/projects
    
    # Clone the project
    git clone https://github.com/alibabacloud-howto/image-search-workshop.git
    
    # Install and build the project
    mvn clean install
    
    # Run the project
    mvn spring-boot:run

    Of course, you can use an IDE (e.g. IntelliJ IDEA) to import, build and run this project.

    Note: you can use the following command if you want to only build the project (skip tests):

    mvn package -Dmaven.test.skip=true
  2. Try the demo

    1. Configure the demo

      • Open your web browser and go to "http://localhost:8080/".
      • If this is the first time you use the application, you will be redirected to the configuration page.
      • Enter your access key and "Product Search instance" details (you can ignore "OSS Base image URL").
    2. Go to the Manage objects page

      • You can add/update/delete products here.
      • It displays all the sample products registered in the database.
    3. Return to the Home page

      • You can upload an image and see the image search result here.
      • If you have added enough products, you should always see 20 results with various scores.

Run as a linux daemon

  1. Create a RPM package

    If you plan to install this demo on a RPM-based Linux distribution, you can type the following command:

    mvn rpm:rpm

    This generates the package "target/rpm/web-image-search-engine/RPMS/noarch/web-image-search-engine-*.noarch.rpm". The RPM contains a fat JAR and a Systemd script. It allows users to easily execute the web server when the machine starts. It also automatically restarts the application after a crash.

  2. Install the RPM package

    If you are using a RPM-based Linux distribution, such as CentOS 7.4+, you can install the RPM with the following commands:

    sudo yum -y update
    sudo yum -y install path/to/web-image-search-engine-latest.noarch.rpm
  3. Execute the service

    You can start the server with the following command:

    sudo systemctl start web-image-search-engine.service

    You can check the logs by running the following command:

    sudo journalctl --unit=web-image-search-engine

    The server should start and listen to the port 8080. If you prefer to use the port 80, you can setup a reverse proxy such as Nginx.

    If you want to automatically run the server when the machine starts, enter the following command:

    sudo systemctl enable web-image-search-engine.service

Tips

After many searches you will find that the results are not always meaningful. For example you will get 20 results even if you search with a picture of an object type that doesn't exist in the database (in fact, the value "20" is hardcoded in the demo source code). This is a limitation of this API, and there is no simple solution. The absolute value of the score doesn't help (unless you search with the exact same picture as a registered object), only its relative value can be used for sorting results.

There are few solutions for this problem:

  • Have a huge database of images, like Taobao.
  • Teach the Image Search API to recognize bad results: for example if the customer only sells furniture, then non-furniture objects should also be registered in the database and marked as "BAD", like this the program can filter the Image Search results by removing the BAD objects.

Online demo page

You can try the demo with the following URL: http://imagesearch.abcdemo.cc/

Thanks

This application uses the following libraries/frameworks/tools:

Support

Don't hesitate to contact us if you have questions or remarks.