Gerando um número aleatório único de 10 dígitos em java

Estou tentando, com o código abaixo, gerar um número aleatório único de 10 dígitos. De acordo com o meu req eu tenho que criar cerca de 5000 números únicos (IDs). Isso não está funcionando conforme o esperado. Também gera números -ve. Às vezes, também faltam um ou dois dígitos no número gerado, resultando em 8 ou 9 números e não em 10.

public static synchronized  List generateRandomPin(){

    int START =1000000000;
    //int END = Integer.parseInt("9999999999");
    //long END = Integer.parseInt("9999999999");
    long END = 9999999999L;

    Random random = new Random();

    for (int idx = 1; idx <= 3000; ++idx){
        createRandomInteger(START, END, random);
    }

    return null;
}


private static void createRandomInteger(int aStart, long aEnd, Random aRandom){
    if ( aStart > aEnd ) {
      throw new IllegalArgumentException("Start cannot exceed End.");
    }
    //get the range, casting to long to avoid overflow problems
    long range = (long)aEnd - (long)aStart + 1;
    logger.info("range>>>>>>>>>>>"+range);
    // compute a fraction of the range, 0 <= frac < range
    long fraction = (long)(range * aRandom.nextDouble());
    logger.info("fraction>>>>>>>>>>>>>>>>>>>>"+fraction);
    int randomNumber =  (int)(fraction + aStart);    
    logger.info("Generated : " + randomNumber);

  }

questionAnswers(7)

yourAnswerToTheQuestion